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The Keyboard and Display 


Organization of the Display 


For most operations, the display is divided into three sections, as 
shown below. This configuration is called the stack display. The 
following topics describe each of these sections. 


- Status area 


BEL 
Stack ——< z 

| i: 
Command lt 
line ar A+B + 


-—— Menu labels 


The Status Area, Annunciators, and Messages 
The status area displays the following: 
a Annunciators. These indicate the status of the calculator. 


w The current directory path. When you turn the calculator on for 
the first time, the current directory path is € HOME $. Directories 
divide memory into parts, much as files do in a file cabinet. 
(Directories are covered in chapter 5.) 


w Messages. These inform you when an error has occurred, or provide 
other information to help you use the calculator more effectively. 


The table that follows describes the annunciators. The first six appear 
at the top of the display, and the rest (along with the directory path) 
share their “territory” with messages. Any message replaces the 
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annunciators and directory path; when you clear the message, the 
directory path and annunciators reappear. 


CA pacan 


Annunciator area —- a © 8 >œ 
7 AG | Message 
Current directory —— | area j 
path 
+B 4 
VECTRIMATR| LIST | HYP | REAL | BASE | 
Annunciators 
Symbol Meaning 

Eal Left-shift is active (you pressed (4 )). 

fad Right-shift is active (you pressed (@)). 

a The alpha keyboard is active (you can type letters and 
other characters). 

(o) (Alert.) An appointment has come due, or a low 
battery condition has been detected. See the message 
in the status area for information. (If no message 
appears, turn the calculator off and on. A message 
describing the cause of the alert will appear.) 

x Busy—not ready to process new input. (However, the 
calculator can remember up to 15 keystrokes while 
busy and then process them when free.) 

>> Transmitting data to an external device. 
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Annunciators (continued) 


Symbol Meaning 


Radians angle mode is active. 

Grads angle mode is active. 
Polar/Cylindrical coordinates mode is active. 
Polar/Spherical coordinates mode is active. 


Program execution has been halted. 


The indicated user flags are set. 


The user keyboard is active for one operation. 


The user keyboard is active until you press (4) USER). 


ALG Algebraic-entry mode is active. 


PRG Program-entry mode is active. 


The Stack 


The stack is a series of memory storage locations for numbers and 
other objects. The locations are called levels 1, 2, 3, ete. The number 
of levels changes according to how many objects are stored on the 
stack—from none to hundreds. 


As you enter new numbers or other objects on the stack, the stack 
-grows to accommodate them: the new data moves into level 1, and 
older data is “bumped” to higher levels. As you use data from the 
stack, the number of levels decreases as the data moves down to lower 
levels. 


The stack display shows level 1 and up to three additional levels. 
Any additional levels are maintained in memory, but normally aren’t 
displayed. 


For more information about the stack and command line, see “Using 
the Stack for Calculations” on page 3-1. 
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The Command Line 


The command line appears whenever you start keying in or editing 
text. The stack lines move up to make room. If you type more than 
21 characters, information scrolls off the left side of the display, and 
an ellipsis (...) appears to tell you there is more information “in that 
direction.” 


The command line is closely tied to the stack. You use it to key in (or 
edit) text and then to process it, transferring the results to the stack. 


After you finish using the command line, the stack display moves back 
down into the command line area. 


For more information about the stack and command line, see “Using 
the Command Line” on page 2-7. 


Menu Labels 


Menu labels across the bottom of the display show the operations 
associated with the six white menu keys across the top of the 
keyboard. These labels change depending on the menu you select. 
See “Working with Menus” on page 1-9 for information about using 
menus. 


Organization of the Keyboard 


The HP 48 keyboard has six levels (or “layers”) of functions, each 
containing a different set of keys: 


a Primary keyboard. Represented by the labels on the key faces; 


for example, Œ), (7), (ENTER), (TAN), and (A) are on the primary 
keyboard. 


m Left-shift keyboard. Activated by pressing the purple (4) key. 
Left-shift keys are labeled in purple and located above and to the 
left of their associated primary keys. To execute ASIN, for example, 


press the (4) key followed by the key. 


a Right-shift keyboard. Activated by pressing the green (p>) key. 
Right-shift keys are labeled in green and located above and to the 
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right of their associated primary keys. To execute LN, for example, 


press the (@) key followed by the key. 


Alpha keyboard. Activated by pressing the (œ) key. Alpha keys 

are labeled in white and located to the right of their associated 
primary keys. Alpha keys are all capital letters. To generate “N”, 
for example, press (a) followed by the key. Notice that when 
the alpha keyboard is active, the œ annunciator appears. Notice also 
that the number pad still generates numbers. 


Alpha left-shift keyboard. Activated by pressing (œ) and then (#4). 
Alpha left-shift characters include lowercase letters, along with some 
special characters. (Alpha left-shift characters are not shown on the 
keyboard.) To type “n”, for example, press (æ), then (4), and then 
G10), 


Alpha right-shift keyboard. Activated by pressing (œ) and then 
(œ). Alpha right-shift characters include Greek letters and other 
special characters. (Alpha right-shift characters are not shown on 
the keyboard.) To generate A, for example, press (œ), then (œ), and 
then (NXT). 


The unshifted and shifted Alpha keyboards are shown on page 2-3. 
Note also that you can easily access all displayable characters on the 
HP48 using the CHARS application (see page 2-4). 


(+ | (sto) Eva (q) W) pp) | 


H 
$ 


( ENTER | (+/-) (EEX) (DEL) (< 
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When you press (4) (left-shift) or (>) (right-shift), the Ea or fad 


annunciator appears in the display. 


To cancel a shift key: 


m To clear the shift key, press it again. 
a To change to the other shift key, press the other shift key. 


Applications and Command Menus 


Some keys have both right- and left-shifted labels printed above, but 
many have only one of the two. 


Keys that have only labels printed in green represent applications. 
Each of these keys launches an application with specially designed 
user-interfaces that make it easier for you to interact with that 
application. The HP 48 has twelve application keys: 


(=) CHARS) 
DE 


CT) 


CERRY) 
COUR) 


ETE) 
MED 
JE) 
OE 
OG 


Displays a catalog of all 256 characters used by the 
HP 48 (see chapter 2). 

Provides access to over 300 scientific equations, 
accompanying diagrams and variable sets, 40 physical 
constants, and the Multiple Equation Solver (see 
chapter 25). 

Facilitates transfer of data between the HP 48 and 
printers, computers, and other HP 48s (see chapter 
27). 

Allows you to access commands and programs on 
plug-in cards and port memory (see chapter 28). 
Provides access to the Variable Browser application 
for organizing and managing stored variables (see 
chapter 5). 

Provides access to the Calculator Modes screen and 
the Flag Browser (see chapter 4). 

Provides access to the PLOT application and its 15 
plot types (see chapters 22, 23, and 24). 

Provides access to the SOLVE application and its 5 
kinds of equation-solving functions (see chapter 18). 
Accesses the Interactive Stack application (see 
chapter 3). 

Accesses the STAT (statistics) application and its 
data analysis and curve-fitting operations (see chapter 


21). 
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(>) SYMBOLIC) Accesses the symbolic algebra and calculus capabilities 
of the HP 48 (see chapter 20). 

(>) (TIME) Accesses the HP 48’s Alarm Browser and clock-setting 
features (see chapter 26). 


Each of these applications also has a left-shifted version that displays 
the companion command menu for that application. For example, 
pressing (44)(STAT) displays a menu of commands that pertains to 
statistical analysis. 


Command menus provide convenient access to commands for inclusion 
In programs, or when using functions directly from the stack display 
instead of from an application. 


Cursor Keys 


The six cursor keys differ from other keys because their behavior 
depends on whether a cursor is currently displayed. Their behavior 
when a cursor is being displayed is summarized below: 


The Behavior of Cursor Keys 


Key No Shift Right Shift 
K) Moves the cursor left. Moves the cursor to the 
beginning. 
œ) Moves the cursor right. Moves the cursor to the end. 
Moves the cursor down. Moves the cursor to the 
bottom (or end). 
Moves the cursor up. Moves the cursor to the top 
(or beginning). 


© P e| e 


E Deletes the current Deletes all characters to the 
character. end. 
Deletes the previous Deletes all previous 
character. characters to the beginning. 


The Keyboard and Display 1-7 


Whenever there is no cursor being displayed, pressing any of these six 
keys executes the operation indicated by the colored label above them: 


m (4) (or (PICTURE)) displays the current picture. 
m (>) (or (SWAP)) swaps the objects on levels 1 and 2 of the stack. 


m (A) (or (STACK)) begins the Interactive Stack application. 

m (¥) (or (VIEW)) puts the object on level 1 of the stack into its “best” 
viewing mode (see page 2-10). 

m (or (CLEAR)) clears the stack. 

a (or (DROP)) drops the object on level 1 from the stack. 


The CANCEL Key 


When the HP 48 is on, becomes the key. Generally, 
halts the current activity—so you can immediately start your 
next task or recover from an unexpected situation. 


To stop the calculator: 
m To delete the command line, press (CANCEL). 


m To cancel a special environment and restore the stack display, press 


CANCEL J. 
m To cancel a running program, press (CANCEL). 


Menus: Extending the Keyboard 


The HP 48 uses menus extensively to accommodate its hundreds of 
built-in commands and functions. 


A menu is a set of operations defined for the six blank menu keys at 
the top of the keyboard. The current operations are described by the 
six menu labels at the bottom of the display. 
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Some menus have multiple sets of labels, called pages. If a menu label 
has a tab over its left corner like a file folder, it selects another menu 
called a submenu. 


Working with Menus 


To display a menu: 


1. Press the key or keys corresponding to the menu you want. 

2. Menus with more than six entries are extended over two or more 
pages. If necessary, change to the menu page you want: 
a To move to the next page, press (NXT). 
m To move to the previous page, press (1) (PREV). 
Note that you will eventually cycle through and return to the first 
page. 


When you want to go to another menu, simply press the keys for 
that menu—you don’t “get out” or “back out” of one menu to go to 
another—you just go to the new one. 
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To display the previous menu: 


m Press (@)(MENU). 


Occasionally you may be working primarily with a particular menu, 
but need to use commands in another menu. For example, you may 
need to briefly leave the second page of the SYMBOLIC menu to use a 
command in the second page of the MTH PROB menu. 


When you switch from one menu to another, the HP 48 stores the 
identity and page number of the last menu you were in. Pressing 


(p>) (MENU) (found over the key) returns you to that menu. 
Menus that list only additional menus (such as the MTH and PRG 


menus) aren’t stored as the last menu. 


To select a function from a menu: 


w Press the menu key below the label of the operation. 
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Entering and Editing Objects 


The basic items of information the HP 48 uses are called objects. For 
example, a real number, an equation, and a program are each an 
object. An object occupies a single level on the stack, and can be 
stored in a variable. 


The HP 48 can store and manipulate many types of objects, 
including real and complex numbers, binary integers, arrays, algebraic 
expressions, programs, graphics, text strings, and lists. Many of the 
HP 48’s operations are the same for all types of objects, while others 
only apply to particular types of objects. 


Keying In Numbers 


To key in a simple number: 


1. Press the appropriate number and Ç) keys. 
2. If the number is negative, press @/). 


To correct a typing mistake: 


a Press () (the backspace key) to erase the mistake, then retype it 
correctly. 


To delete the entire number from the command line: 
m Press (CANCEL). 
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Example: Enter the number —123.4 in the command line. 
Step 1: Key in the digits. 


1236) 4 {23.4 


WECTRIMATR] List | HYP | REAL | BASE | 


Step 2: Make the number negative. 


ZA -123.44 
WECTRIMATR] LIST| HYP | REAL | BAZE | 


Press (CANCEL) (the (ON) key) to delete the command line. 


To key in a number as a mantissa and an exponent: 


1. Key in the mantissa. If it’s negative, press to change its sign. 


2. Press (EEX). (It types an E for “exponent.” ) 
3. Key in the exponent—the power of 10. If it’s negative, press (*/-). 


Keying In Characters (the Alpha Keyboard) : 


The HP 48 features an “alpha” keyboard that lets you type letters and 
other characters into your data. Activate the alpha keyboard using the 
(a) key. (The d annunciator turns on while the alpha keyboard is 
active.) 


When you press the (@) key, you can type in capital letters. The 
letters available are printed in white to the lower right of each key. 
In addition, the left-shift and right-shift keys provide additional 
characters: 


a The left-shifted alpha keyboard types in lowercase letters. 
w The right-shifted alpha keyboard types in Greek letters and 
miscellaneous symbols. 


To keep the HP 48 keyboard from appearing too cluttered, most of the 
alpha left- and right-shift keys are not shown on it. For your reference, 
the next illustration shows how keys are interpreted when the a 
annunciator is on. 
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To key in a single character: 


m Press (œ) and key in the character. 
or 
m Hold down (œ), key in the character, then release @)} 


To key in several characters: 


m Press (a)(@), key in the characters, then press (a) again. 
or 
a Hold down (q), key in the characters, then release (aq). 
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Pressing (œ) once activates Alpha-entry mode for one character only. 
Pressing (@) twice locks Alpha-entry mode. Alpha-entry mode then 
remains active until you press (œ) again or press (ENTER) (or (CANCEL)) 
. You can also press and hold down (œ) while you type several 
characters in a row. If you prefer, set Flag —60 to enable a single 
press of (œ) to lock Alpha-entry mode. 


To lock or unlock the lowercase keyboard: 


m If a is locked on, press (€)(@) to lock lowercase mode. 

m If a is off, press (@)(@)(4)(@) to lock lowercase mode. 

a To unlock lowercase, press (4)(@). Also, terminating the entry 
process—by pressing (ENTER) or (CANCEL), or by executing a 
command—-automatically unlocks lowercase mode. 


While in lowercase Alpha-entry mode, you must use () to get 
uppercase letters. Lowercase mode automatically unlocks when you 


press (ENTER) or (CANCEL J, or execute a command. 


Keying in Special Characters 


Although most of the 256 characters that can be displayed on the 
HP 48 are available on the Alpha keyboard, it is easy to forget the 
particular sequence of keystrokes needed for the less-frequently used 
characters. 


The CHARS application is designed to avoid this problem by enabling 
you to select characters directly from the display and insert them at 
the cursor point. CHARS displays the HP 48’s characters 64 at a 
time, along with the number of each character and the keystroke used 
to type it in from the alpha keyboard. 
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To use CHARS to view or key in characters: 
- Press (@)(CHARS). A display of 64 characters appears. 


1 
2 


T Or 


. Use = 64 and +64 


to cycle through the pages of characters. 


. Use the arrow keys (G@), (®), (@), and (¥)) to select a character. 
Notice that the character’s number is shown at lower right, and its 


keystroke is shown at lower left. 
. To insert the selected character at the cursor point, press 


. Repeat steps 2, 3, and 4 to insert additional characters. 


. When you’ve finished, press or to exit CHARS. 


Keying In Objects with Delimiters 


Real numbers represent one type of object. Most other types of 
objects require special delimiters to indicate which type of object they 
are. 


Here’s a partial list of different types of objects and their 
corresponding delimiters. 
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Objects Delimiters Keys Examples 


Real number none 
Complex number Eï 
String 
Array p] 
Unit 


Program 


Algebraic 
List io} 


Built-in command none 


Name uO C) “OL or 


t h si L. t 


To key in an object using delimiters: 


m To key in data within opening and closing delimiters, press the 
delimiter key, then key in the data. (The delimiter key types both 
delimiters.) 

a To insert a single delimiter within the data, press the delimiter key 
where required, then delete the one you don’t want. 


Even large-scale objects such as algebraics and arrays can be entered 
in the command line. 
To key in an algebraic object using the command line: 


1. Press (7) to type the delimiters. 

2. Key in the numbers, variables, operators, and parentheses in the 
expression or equation in left-to-right order. Press (®) to skip past 
right parentheses. 


To key in a matrix using the command line: 


1. Press (D) to begin the array and (4)() to begin the first row. 
2. Key in the first row. Press between each element. 
3. Press (©) to move the cursor past the 1 row delimiter. 
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4. Optional: Press ()(2) (new line) to start a new row in the 
display. 

. Key in the rest of the matrix. You don’t need to add E ł delimiters 
for subsequent rows—they’re added automatically later. 


6. Press (ENTER). 


Ct 


To key in a vector using the command line: 


1. Press (e) (O) to begin the array. Because a vector is equivalent to a 
single-column matriz, there is no need to group elements into rows 
using additional delimiters unless you specifically want to create a 
row-vector. 

2. Key in the vector elements. Press to separate the elements. 


3. Press (ENTER). 


The HP 48 also provides special entry environments for algebraics 
and arrays that use visually intuitive methods to key in these large 
objects. See chapter 7, “The Equation Writer,” and chapter 8, “The 
MatrixWriter,” for information. 


The command line is essentially a workspace for keying in and editing 
the objects you will enter into the HP 48. The command line appears 
whenever you enter or edit text (except when you’re using the 
Equation Writer application). 


Accumulating Data in the Command Line 


You can key any number of characters into the command line, using 
up to half of the available memory. To enter more than one object in 
the command line, use spaces, newlines (()(€2)), or delimiters to 
separate objects. For example, you can key in 12 34 to enter two 
numbers. 


If you enter an È character outside of a string in the command 
line, both the ® character and the adjacent text are treated as a 
“comment” and are stripped away when you press (ENTER). 


When you type in the command line, characters are normally inserted 
at the cursor position, and any trailing characters move to the 
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right. In addition, you can use the following keys to edit data in the 
command line: 


Command Line Operations 


Key Description 


OIO Move the cursor left and right in the command line. 
(A and (SJS) move the cursor to the far left and 
far right.) 

(4) (¥) If the command line has more than one line, move the 


cursor up and down one line. ((@)(A) and (@@)(¥) move 


the cursor to the first and last line.) 


If the command line has only one line, (A) selects the 
Interactive Stack, and (¥) displays the EDIT menu. 
(*) Erases the character to the left of the cursor. 
DEL Deletes the character beneath the cursor. 
(DEDIN) | Displays the EDIT menu, which contains additional 
editing operations. 
(@)(ENTRY) | Changes the command-line entry mode to 
Program-entry mode or Algebraic/Program-entry 
mode, as described below. 
Processes the text in the command line—moves objects 
to the stack and executes commands. 


CANCEL Discards the entire command line. 


Selecting Command-Line Entry Modes 


The HP 48 has four command-line entry modes that make it easier for 
you to key in objects. 


m Immediate-Entry Mode. (Activated automatically, and indicated by 
no entry-mode annunciator.) In Immediate-entry mode, the contents 
of the command line are entered and processed immediately when 
you press a function or command key (such as Œ), GIN), or (6TO)). 
Immediate-entry mode is the default mode. 


a Algebraic-Entry Mode, (Activated when you press (), and 
indicated by the i. annunciator.) Algebraic-entry mode is 
used primarily for keying in names and algebraic expressions for 
immediate use. In Algebraic-entry mode, function keys act as 
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typing aids (for example, types = 
executed immediately (for example, (STO) or (;)(PURGE)). 


(4) (3), and indicated by the annunciator.) Program-entry 
mode is used primarily for entering programs and lists. It’s also 


used for command-line editing (@4)(EDIT)). In Program-entry mode, 


function keys and command keys act as typing aids (for example, 


types , and (STO) types 


3). Only non-programmable 


operations are executed when you press a key (for example, (ENTER), 


(VAR), or (>) (ENTRY)). 


m Algebraic/Program-Entry Mode. (Activated when you press (7) 
while in Program-entry mode, and indicated by the £ 


and 
annunciators.) Algebraic/Program-entry mode is used for keying 
algebraic objects into programs. 


To change entry modes manually: 
m Press (p>)(ENTRY). 


Pressing (@)(ENTRY) switches from Immediate-entry to Program-entry 


mode, and between Program-entry and Algebraic/Program-entry 
modes. 


). Other commands are 


reine - l | ENTRY | m h [ ENTRY | per EEN we 
| Immediate e Enny J | Program fee | Algebraic/Program 
o emy o ™ ety | e Ñ Oy 

>| ENTRY | 


(>) (ENTRY) allows you to accumulate commands in the command 
line for later execution. For example, you can manually invoke 


Program-entry mode to enter 4 3 + J into the command line, and 


easier to edit algebraic objects in programs. 


Example: Calculate 12 — log(100) by including the LOG command 
in the command line. 


Step 1: Enter the command line. 


12 (SPC) 100 (œ) ENTRY) 
A) 


12 168 LOG 4 
ECTRIMATR] List | HVE [REAL [EASE 
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Step 2: Process the command line to complete the calculation. 


ENTER) ©) 16 


j: 
ECTREMATR| LIST | HYP | REAL | ERSE | 


Recovering Previous Command Lines 
The HP 48 automatically saves a copy of the four most recently 


executed command lines. 


To retrieve a recent command line: 


1. Press (¢>)(CMD) (found over the key). l 
2. Select the command you want to retrieve, using the (A) and (¥) 
keys, and press UE 


Viewing and Editing Objects 


You can’t always see all the objects on the stack—you can see only 
the beginning of large objects, and you can’t see objects that have 
changed levels and scrolled off the display. 


To enable you to view any object on the stack, the HP 48 gives 
you a choice of environments for viewing and editing objects. An 
environment defines a particular display and keyboard behavior—it 
determines how you see and change the object. 


To view or edit an object: 


1. Depending on the location of the object and the desired 
environment, press the keys listed in the table below. 
2. View or edit the object according to the rules of the environment. 
3. Exit the environment: 
a To exit after viewing, press (CANCEL). 
m To save changes you’ve made, press (ENTER). 
a To discard changes you’ve made, press (CANCEL). 
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Viewing or Editing an Object 


Location of Viewing / Editing Keystrokes to 
Object Environment View or Edit 
Level 1 Command line (4) (EDIT) | 
Best (see below) (W) 
Level n Interactive Stack (A) to level n, 4] 
Variable name Command line O name (4) (EDT) 
Best C name PIR) 
) 


The command line is the simplest viewing and editing environment: 


a The EDIT menu is displayed, which provides operations that make 
it easier to edit large objects. (See “Using the EDIT Menu” below.) 


m Real and complex numbers are displayed with full precision 
(standard format), regardless of the current display mode. 


a Programs, lists, algebraics, units, directories, and matrices are 
formatted onto multiple lines. 


m All the digits of binary numbers, all the characters in strings, and 
entire algebraic expressions are displayed. 


The “best” editing environment is the one that the HP 48 determines 
is most appropriate based on the type of object: 


a Algebraic objects and unit objects are copied into the 
Equation Writer environment in scrolling mode. To edit the 
equation, enter selection mode by pressing (€) (see chapter 7). 

m Matrices are copied into the MatrixWriter environment (see chapter 
8). 

a All other object types are copied into the command line. 


The Interactive Stack is an environment for viewing, editing, and 
manipulating all objects on the stack. (See “The Interactive Stack” on 
page 3-6.) 
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Using the EDIT Menu 


Whenever the command line is present, you can press (4) (EDIT) to 
get the EDIT menu. The EDIT menu is also displayed whenever you 
perform a viewing or editing operation as described in the previous 
section. 


Certain operations in the EDIT menu use the concept of a word—a 
series of characters between spaces or newlines. For example, pressing 
LF skips to the beginning of a word. The following table lists the 
operations available in the EDIT menu: 


EDIT Menu Operations 


Description 


Moves the cursor to the beginning of the current word. 


Moves the cursor to the beginning of the next word. 


EDEL Deletes characters from the beginning of the word to 
the cursor. 
DELS Deletes characters from the cursor to the end of the 
word. 
(>) EBEL. | Deletes characters from the beginning of the line to the 
cursor. 
(>) GEL. | Deletes all characters from the cursor to the end of the 
line. 
IHS Switches the command-line entry mode between Insert 


mode (# cursor) and Replace mode (Ẹ cursor). A æ in 
the menu label indicates Insert mode is active. 
Activates the Interactive Stack. (See “The Interactive 
Stack” in chapter 3.) 
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Stack 


The stack is a series of storage locations for numbers and other 
objects. In general, you will use the HP 48 by entering numbers and 
other objects onto the stack, then executing commands that operate 
on the data. 


Using the Stack for Calculations 


You ordinarily do calculations by entering objects onto the stack 
and then executing the appropriate functions and commands. The 
fundamental concepts of stack operations are these: 


a A command that requires arguments (objects the command acts 
upon) takes its arguments from the stack. Therefore, the arguments 
must be present before you execute the command. 


m The arguments for a command are removed from the stack when the 
command is executed. 


w Results are returned to the stack so that you can see them and use 
them in other operations. 


Making Calculations 


When you execute a command, any arguments in the command 

line are automatically put onto the stack before the command is 
executed. This means you don’t always have to press to put 
the arguments on the stack—you can leave one or more arguments in 
the command line when you execute the command. (You should still 
think of the arguments as being on the stack, though.) 
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To use a one-argument command: 


1. Enter the argument into level 1 (or into the command line). 
2. Execute the command. 


Example: Use the one-argument commands LN ((®)(LN)) and INV 
(G) to calculate 1/In 3.7. 


3.7 CA 


Li . P64331518286 
[Ecte] matk] List | VP [REAL [EASE | 


To use a two-argument command: 


1. Enter the first argument and then the second argument. The first 
argument should be in level 2, and the second in level 1 (or in the 
command line). 

2. Execute the command. 


A two-argument command acts on the arguments (objects) in levels 1 
and 2, and returns the result to level 1. The rest of the stack drops 
one level—for example, the previous contents of level 3 move to 

level 2. The arithmetic functions (+, —, x, /, and ^) and percent 
calculations (%, %CH, and %T) are examples of two-argument 
commands. 


Example: Calculate 85 — 31. 


85 (ENTER) 31 ©) l 54 


[VECTR HATA] LIST | HYP [REAL [EASE | 


Example: Calculate v45 x 12. 
45 12 (x) 


1: dB. 49944719 
BECTRIMATE] LizT | HYP [REAL | BASE | 


Example: Calculate 4.771. 


4.7 2.1 23. forerr goo? 


Le 
WECTRIMATE| LIET | HYP [REAL [ERSE] 


To enter more than one argument in the command line: 
a Press to separate arguments. 
Example: Calculate 42401. 
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? 


2401 (SPC) 4 1: 
EE [ECTE] MATE LIST | HYP [REAL | BAZE | 


Since the HP 48’s stack retains previous results, it makes it especially 
easy to perform chain calculations. 
To use previous results (chain calculation): 


1. If necessary, move the previous results to the proper stack level for 
the command (see “Manipulating the Stack,” below). 

2. Execute the command. 

Example: Calculate (12 + 3) x (7 + 9). 

Step 1: Perform the additions. 


2 ENTER) 3 © 
7 (ENTER) E 


Step 2: Notice that the two intermediate results remain on the stack. 
Now, multiply them. 


3) 


ve 
MECTR[MATR| LIST | HYP | REAL | EASE | 


Example: Calculate 23? — (13 x 9) + 2. 
Step 1: First, calculate 23” and the product 13 x 9. 


BICIE 
13 (ENTER) 9 O 


Step 2: Subtract the two intermediate results and calculate 5, 


O : 412 
GDS ra 


Step 3: Add the two results. 


B te, ia cain Te 


[VECTRA MATR] List | HYP | REAL | 
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Manipulating the Stack 
The HP 48 enables you to reorder, duplicate, and delete specific 
objects on the stack. 


To swap the objects in levels 1 and 2: 
m Press (€)(§WAP) (or (>) when no command line is present). 


The SWAP command is useful with commands where the order is 
important, such as —, /, and ^. 


Example: Use (€)(SWAP) to help calculate TETE 
Step 1: First, calculate VI3 +8. 


"GED*OO omandi SESE 


Step 2: Enter 9 and swap levels 1 and 2. 


9 GMP) 


Step 3: Divide the two values. 


© 


To duplicate the object in level 1: 


m Press (4)(STACK) (NXT) [UF (or press if no command line 


is present). 


The DUP command duplicates the contents of level 1 and bumps the 
rest of the stack up one level. 


Example: Calculate ;+; + esp 


Step 1: First, calculate the inverse of 47.5 and duplicate the value. 


5 CH (ENTER) 2: 210526315789- 
‘ l: 3156315 709E-2 
[MATE] LIST | HYP | REAL | BASE | 


3-4 Stack 


Step 2: Raise the value to the 4th power. 


105 


Step 3: Add the result to the original value. 


1: z. AS28288 169E-2 
VECTRIMATR) List | HYP [REAL [EASE | 


To delete the object in level 1: 
a Press ()(OROP) (or (¢) when no command line is present). 
When you execute the DROP command, the remaining objects on the 


stack drop down one level. 


To clear the entire stack: 
m Press (4)(CLEAR) (or when no command line is present). 


Recalling the Last Arguments 
The LASTARG command ((@*)(ARG)) places the arguments of the 


most recently executed command on the stack so that you can 
use them again. This is particularly useful for more complicated 
arguments, such as algebraics and matrices. 


To recall the arguments of the last command: 
m Press (->)(ARG). 
Example: Use (@)(ARG) to help calculate [n2.3031 + 2.3031. 


Step 1: Calculate In 2.3031, then retrieve the argument of LN. (ARG) 
is above the key.) 


2.3031 Œ) 
ERD 
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Step 2: Add the two numbers. 


1: 3. 13735684152 
VECTRIMATE| List | VP [REAL | ERSE] 


Restoring the Last Stack (UNDO) 


The UNDO command (¢>)(UNDO) restores the stack to the way it was 
before you executed the most recent command. 


To restore the stack to its previous state: 


m Press ()(UNDO). 


The Interactive Stack 


The normal stack display is a “window” that shows level 1 and as 
many higher levels as will fit in the display. The HP 48 also features 
the Interactive Stack, a special environment in which the keyboard 
is redefined for a specific set of stack-manipulation operations. The 
Interactive Stack lets you do the following: 


m Move the window to see the rest of the stack. 

m Move and copy objects to different levels. 

a Copy the contents of any stack level to the command line. 
m Delete objects from the stack. 

m Edit stack objects. 

a View stack objects in an appropriate environment. 


When you activate the Interactive Stack, the stack pointer turns on 
(pointing to the current stack level), the keyboard is redefined, and 
the Interactive Stack menu is displayed. You must exit the Interactive 
Stack before you can execute any other calculator operations. 
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Current 
stack level ——— 


ik — { Al. 
echo | AmE 


AL Pick [ROLL 


Stack pointer 


To use the Interactive Stack: 
1. Press ()GTACK) (or VETE in the EDIT menu) to activate the 


Interactive Stack. (If no command line is present, press (@).) The 
stack pointer appears on level 1. 
2, Use the keys described in the following table to view or manipulate 


the stack. 


3. Press (ENTER) (or (CANCEL)) to leave the Interactive Stack and show 


the changed stack. 
4. Optional: To cancel changes made to the stack in the Interactive 


Stack, press (¢>)(UNDO). 


If a command line is present when you select the Interactive Stack, 


only the Et 


key appears in the menu because all you can do is 


copy (echo) an object from a higher stack level to the cursor position 
in the command line. 


Interactive-Stack Operations 


Key 


Description 


(>) (STACK) (or (A) when no command line is present): 


Copies the contents of the current level into the 
command line at the cursor position. 

Views or edits the object in the current level using the 
best environment. Press when finished editing 
(or to abort). 

Views or edits the object specified by the name or level 
number using the best environment. Press 
when finished editing (or to abort). 


Copies the contents of the current level to level 1 


(equivalent to n PICK). 
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Interactive-Stack Operations (continued) 


Description 


ove: gon 


REEF 
LEVEL 


(4) 


Qam 


Moves the contents of the current level to level 1, and 
rolls upwards the portion of the stack beneath the 
current level (equivalent to n ROLL). 

Moves the contents of level 1 to the current level, and 
rolls downwards the portion of the stack beneath the 
current level (equivalent to n ROLLD). 

Creates a list containing all the objects in levels 1 
through the current level (equivalent to n —LIST). 
Duplicates levels 1 through the current level (equivalent 
to n DUPN). For example, if the pointer is at level 3, 
levels 1, 2, and 3 are copied to levels 4, 5, and 6. 
Deletes levels 1 through the current level (equivalent to 
n DROPN). 

Clears all levels above the current level. 

Enters the current level number into level 1. 

Moves the stack pointer up one level. When preceded 
by (44), moves the stack pointer up four levels 


((4)(gUp) in the following keyboard illustration); 


when preceded by (f>), moves the stack pointer to the 
top of the stack ((@)(@) in the following keyboard 
illustration). 


Moves the stack pointer down one level. When 
preceded by (|), moves the stack pointer down four 


levels (()(PgDn) in the following keyboard 


illustration); when preceded by (>), moves the stack 
pointer to the bottom of the stack ((@)(¥) in the 
following keyboard illustration). 


Copies the object in the current level into the 
command line for editing. Press (ENTER) when finished 


editing (or to abort). 

Deletes the object in the current level. 

Selects the next page of Interactive-Stack operations. 
Exits the Interactive Stack. 


Exits the Interactive Stack. 
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Most of the operations in the Interactive Stack menu have equivalent 
programmable commands (see “Stack Command Menu” on page 3-11). 


The redefined keyboard for the Interactive Stack looks like this: 


ea ee 
| 
( j T ) 
Sai: sees 
| PgUpaA PREV 
_ : ae 
Edits iC JC CD CD LA) (w) 
current | PgDn y 
level ~ y 4 f gi P o) 
p oe L } O ad Neate _) as LJ 
Exits | L J Stes — L p C J S J | | | 
interactive | i R l ; | Deletes 
stack ————— TRE \ \ | |-——— current 
‘ = ENTER- $] (t-j ins hiy e | level 
wo ee eae l ; , 
\ | |d | | J | ) | 9 | 
a í 5 = aak ae Ñ | 
LAR ) Piel i j 


To copy an object from the stack into the command line: 


1. Put the cursor at the point in the command line where you want 
the object pets: 

2. Press (4)(EDIT) STE 

3. Press (A) and (¥) to to move é the Interactive Stack pointer to the 
desired object and press EG HO. 

4. Press (ENTER) (or (CANCEL)) to leave the Interactive Stack. 
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Example: Use the Interactive Stack to insert the; mimber 1.2345 into 
the command line, creating the list £ 


Step 1: Put these numbers on the stack. 


1.2345 
2.3456 
3.4567 (ENTER) 


Step 2: Start entering the list. 


aoa 


Step 3: Select the Interactive Stack. 


Step 4: Move the pointer to level 3, echo the object, and leave the 
Interactive Stack. 


DD ECHO 


Step 5: Put the list on the stack. 


SIPISIPS] EDEL [DELS [INS [TETE] 
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Stack Command Menu 


The following table describes the programmable commands that 
manipulate the stack. These commands are available from the 


(4) (STACK) command menu. 


Command/Description 


Example 


Input 
| DEPTH Returns the a 16 | 
| number of objects on the ze i6 wir | 
stack. Le sii 2 
ae Ten s L 
DROP2 Removes the Be Le 
objects in levels 1 and 2. zi ie 
La Z le 
DROPN Removes the first | 43 
n + 1 objects from the stack | 2: 
(n is in level 1). Shown in  ž: 
menu as RFR. Le 
DUP Duplicates the object | 3: 
in level 1. 2: 
jE 


DUP2 Duplicates the 
objects in levels 1 and 2. 


aw 


bee fa tne of. 
ae oa un 


objects on the stack, starting 
at level 2 (n is in level 1). 


ap ths 


ee se 


fete Phi DRE Pin 


BH å an uR nn 
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fo an. Example 


Command/ Description 


OVER Returns a copy of 3 
the object in level 2. z 


PICK Returns a copy of 
the object in level n + 1 to 
level 1 (n is in level 1). 


se 
hs 
ae 
da 
i 
he 


ROLL Moves object in Se 
level n + 1 to level 1 (n is in | 43 
level 1). 3: 
Le 
ROLLD Rolls down a Bi 12] 63 
portion of the stack between | 3: 34 | Re 
level 2 and level n + 1 (nis | 43 oe jdi 
in level 1). Be FS | Se 
Le 4 Le 
| eee ae See = 
ROT Rotates the first 2: le) 3 
three objects on the stack Z: 34 |Z: 
(equivalent to 3 ROLL). ik 36 |i: 
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Modes 


The HP 48 operates using many different modes, depending on 

the nature of the operation it’s performing. Many of these modes 
are controlled automatically by the commands you select; others are 
determined by settings that you control. 


The MODES application and its companion command menu give you 
access to those modes you can control. 


The MODES application provides a convenient way for you to control 
the modes the HP 48 uses. 


To use the MODES application: 
m Press (>) (MODES). 


Bess S CALCULATOR MODES Š 
NUMBER FORMAT: Rate] 

ANGLE MEASURE: Degrees 

COORD SYSTEM: Rectangular 


if EEEP — CLOCK aw PMs 


CHOOSE NUMBER DISPLAY FORMAT 
{ fenoos}| [FLAG [ennet] ok | 


The Calculator Modes Screen 


This screen allows you to set the following calculator modes: 


a Display mode for the number format 
a Angle mode 
a Coordinate mode 
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m Beep mode 
a Clock display mode 
a Fraction mark mode 


Setting the Display Mode 


The display mode controls how the HP 48 displays numbers. (Note 
that numbers can be displayed differently than they are stored. 
Regardless of the display mode, numbers are always stored as signed, 
12-digit mantissas with signed, 3-digit exponents.) 


The HP 48 has four display modes: 


m Standard mode (31.<1)—Displays numbers using full precision. All 
significant digits to the right of the decimal point are shown, up to 
12 digits. 

a Fix mode (Fi::)—Displays numbers rounded to a specified number 
of decimal places. Real numbers on the stack are displayed with 
digit separators (separating digits into groups of three): commas (if 
a period is used as the decimal point) or periods (if a comma is used 
as the decimal point). 


w Scientific mode (Si )—Displays a number as a mantissa (with one 
digit to the left of the decimal point and a specified number of 
decimal places) and an exponent. 


a specified number of digits, followed by an exponent that is a 
multiple of 3. 


To set the display mode: 


m Press ()(MODES). 

m Highlight the } POH T: field. 

m Press © =. (Or, press repeatedly to cycle through the fixed 
list of options, and stop when your choice appears in the field.) 
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CALCULATOR MODES 
andard 
ANGIJF i xed 

COR Scientific 
£E Engineering 
CHOOSE NUMBER DISPLAY FORMAT 

o o o eee 


The Number Format Choose Box 


m Select a number format and press GK. 


m If the format is Fix, Sci, or Eng, press (>), type the number of 
display digits, and press (ENTER). 
m Press ; 


Setting the Angle Mode 


The angle mode determines how the calculator interprets angle 
arguments and how it returns angle results. 


Angle Modes 


Mode Definition Annunciator 
Degrees | 1/360 of a circle (none) 
Radians | t /27 of a circle RAD 
Grads |!/400 of a circle GRAD 


To set the angle mode from the MODES application: 
1. Press (@)(MODES). 


2. Use the arrow keys to highlight the AHGLE HE 
3. Do one of the following: 


field. 


a Press GHO to display the list of choices, select your choice, 
and press ~~ QES. 
m Press repeatedly until your choice appears in the field. 
4. Press GE to confirm your choice, or SHEL to cancel it. 
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To set the angle mode directly from the keyboard: 


m Press ($) (RAD) to switch between Radians mode and Degrees 
mode. (If Grads mode had been previously selected in the MODES 
application, this keystroke switches between Radians mode and 
Grads mode instead.) 


Setting the Coordinate Mode 


The coordinate mode affects how complex numbers and vectors are 
displayed. Complex numbers and two- dimensional vectors can be 

displayed i in either rectangular mode (2% 
mode (iF: or £ Ra J). 


=» or £ # Y 3) or polar 


Three- dimensional vectors can be eee in rectangular mode 
), cylindrical mode (E & # Z 1), or spherical mode 


Note that no matter how these objects are displayed, they are always 
stored in rectangular mode, and calculations are based on this internal 
rectangular representation. 


Ge ae 


Two- Dimensional Display Modes 


Rectangular Polar 


A 
* \ 
\ 
T 
J 
/ 


fap) 
P 
k 
| 
| 
ji 
x< 
= 
È 
2, 


[a b] 


| 
| 
| 
| 
| 
| 
| 
| 
L 


Coordinate Systems for Complex Numbers and 2D Vectors 
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ern | 


ow Three-Dimensional Display Modes 
/ f : j 
fy | Rectangular | Cylindrical Spherical | 
/ c DSE: 
\/ = | [abc] [rxy <8 c] | r20 <4] 
PX. i | | 


Coordinate Systems for 3D Vectors 


To set the coordinate mode from the MODES application: 
1. Press (>)(MODES). 


2. Use the arrow keys to highlight the COORD SYSTEM: field. 
3. Do one of the following: 
m Press (HOGS to display the list of choices, select one, and press 


GE 
a Press repeatedly until your choice appears in the field. Note 
that Follar means “polar cylindrical” when 3D vectors are 
displayed. 
4. Press QK to confirm your choice, or CAMEL to cancel it. 


To change the coordinate mode directly from the keyboard: 


m Press (>)(POLAR) to switch between Rectangular mode and Polar 
(cylindrical) mode. If Spherical mode had been previously selected 
in the MODES application, this keystroke switches between 
Rectangular mode and Spherical mode instead. 
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Setting the Beep 


By default, the HP 48 sounds a “beep” whenever an error occurs. You 
can turn this beeper on and off. 


To set the beep using the MODES application: 


1. Press (¢>)(MODES). 

2. Highlight the BEEF field and press #fHE (or @/)) until the 
desired setting is shown (checked—beep is on; unchecked—beep is 
off). 


3. Press GE to confirm your choice, or GAHE to cancel it. 


Setting the Clock Display 
The HP 48 can display a clock that includes the date and time. 


To display the clock: 


1. Press (e)(MODES). 

2. Highlight the LOCE field and press “CHE (or ŒÆ)) until the 
desired setting is shown (checked—clock displayed; unchecked—no 
clock displayed). 

3. Press = OE to confirm your choice, or GAHE to cancel it. 


Setting the Fraction Mark 


A fraction mark is the displayed punctuation separating the integer 
and fractional parts of a real number (the “decimal point”). Because 
different countries use different fraction marks, the HP 48 allows two 
different kinds of fraction marks: the period (.) and the comma (;). 
As the table below indicates, the fraction mark used also changes the 
punctuation used to separate digits and arguments: 


Fraction Mark | Digit Separator Argument Separator 


» (2.456 | » (34: 300. 54) s (2542) | 


» (3.458) | . (24. 366, 54) i (fE4%) | 
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To set the fraction mark: 


1. Press (-®)(MODES). 

2. Highlight the FH; field, and press #fHE (or @/)) until the 
desired setting is shown (checked—fraction mark is comma; 
unchecked—fraction mark is period). 

3. Press GE to confirm your choice, or CANTI to cancel it. 


Most modes are controlled by system flags. The HP 48 has 64 system 
flags, numbered —1 through —64. Each flag can have two states: set 
(value of 1) or clear (value of 0). The system flags and the modes they 
control are described in appendix D. 


You can control modes by directly manipulating the system flags. You 
can access the flags by using the Flag Browser, part of the MODES 
application, or by using the FLAG command submenu. 


Using the Flag Browser 


The HP 48 uses two kinds of system flags: flags that single-handedly 
determine a mode, and flags that work with others to determine a 
mode. The Flag Browser lets you view and set the “single-handed” 
flags. 


To view or change flag settings using the Flag Browser: 


1. Press (->)(MODES). 
2. Press FLAG to begin the Flag Browser. 


General solution 
Constant + symb 
Function + symb 


Payment at end 
+72 + vector 4 


L eae eee 
The Flag Browser 
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3. Use the arrow keys to scroll through the flags. A check-mark to 
the left of the flag number indicates that the flag is set. The text 
describes how the flag’s setting affects the calculator’s function. 

4. Press ~ to change the flag setting. Note that the description 
changes to reflect the new setting. 

5. When you finish, press © to confirm your changes (if any), or 


CAHE to cancel them. 


Using the FLAG Command Submenu 


The commands for setting, clearing, and testing flags are in the 
MODES FLAGS menu (A) (MODES) FLAG ). (They are also 
duplicated in the PRG TEST menu.) These commands take flag 
numbers as arguments. 


To use a flag command: 


1. Enter the number of the flag (negative for a system flag). 
2. Execute the command (see the table below). 


Flag Commands 


Key Programmable Description 
Command = ht, 
(4)(MODES) FLAG or (PRO) TEST (NXT) (NXT)): 
Bia SF Sets the flag. 
EE CF Clears the flag. 
E : FS? Returns true (1) if the flag is set and 
false (0) if the flag is clear. 
BL? FC? Returns true (1) if the flag is clear and 
false (0) if the flag is set. 
ESSE FS?C Tests the flag (returns true (1) if set 
and false (0) if clear), then clears it. 
FEFE FC?C Tests the flag (returns true (1) if clear 
and false (0) if set), then clears it. 


Example: Set the Automatic Alpha Lock to activate after only a 
single press of (œ) (instead of two presses). To do this, set 
system flag —60, which controls the alpha lock: 60 
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To set or clear several flags at once: 


1. From the stack, enter onto level 1 a list of the flag numbers you 
wish to set or clear. 

2. Do one of the following: 
m To set the flags, press (;)(MODES) Fi 
a To clear the flags, press (;)(MODES) Fi 


To recall all flag settings to the stack: 


NXT 


This command returns a list containing two 64-bit binary integers 
representing the current states of the system and user flags. The 
rightmost (least significant) bit corresponds to system flag -1 or user 
flag 1. 


To reset all flags to their defaults: 
a Press (@)(MODES) FLAGS RE 


User Flags 


User flags are numbered | through 64 and are not used by the system. 
What they mean depends on how a user’s program uses them. You 
can set, clear, and test them the same way as with system flags. 


User flags 1 through 5 appear as numbers in the display when they are 
set. 


MODES Submenus 
The MODES command menu contains three submenus whose 
commands act as keyboard shortcuts for changing the states of 
particular modes, and as programmable commands. Each of these 
submenus contains special menu labels that indicate the state of the 


modes represented. When a menu label has a æ in it, that mode is 
active. 
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MODES Operations 


Key 


Description 


Number Format Modes (“4)(MODES) FMT ) 


Sets the display mode to Standard. 


Sets the display mode to Fix using the number on level 1 for the 
number of decimal places. 


Sets the display mode to Scientific using the number on level 1 for 
the number of decimal places. 


Sets the display mode to Engineering using the number on level 1 for 
the number of mantissa digits to be displayed after the first 
significant digit. 

Switches the fraction mark between period and comma. 


Switches between displaying a multiline level 1 as multiple lines (# 


in label) and as a single-line followed by an ellipsis. 
Angle Measure Modes ((#4)(MODES | 


cYLIN 
SPHER 


Sets the angle mode to Degrees. 

Sets the angle mode to Radians. 

Sets the angle mode to Grads. 

Sets the coordinate mode to Rectangular. 
Sets the coordinate mode to Cylindrical. 


Sets the coordinate mode to Spherical. 


Miscellaneous Modes ((“)(MODES) MTSE ). 


Switches between errors beeping (# in label) and not beeping. 


Switches between displaying (# in label) and not displaying a clock. 
Switches between symbolic (# in label) and numeric evaluation of 
symbolic expressions. 

Switches between saving (# in label) and not saving the last stack. 
Affects the action of (@)(UNDO). 

Switches between saving (# in label) and not saving the last 
arguments. Affects the action of œ) (ARG). 

Switches between saving (# in label) and not saving in memory the 


last command line. Affects the action of (>) CMD}. 


Switches between displaying (# in label) and not displaying prompt 
messages and data automatically. 
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The HP 48 has two types of memory: 


a Read-only memory (ROM). ROM is memory that’s dedicated to 
specific operations and cannot be altered. The HP 48 has 512 KB 
(kilobytes) of built-in ROM, which contains its command set. 
Except for the HP 48G model, you can expand your calculator’s 
ROM by installing plug-in application cards (described in chapter 
28). 


m Random-access memory (RAM). RAM is memory that you can 
modify. You can store data into RAM, modify its contents, and 
purge it. Except for the HP 48G model, you can increase your 
calculator’s RAM by adding memory cards (described in chapter 
28). 


RAM is also called user memory because it’s memory that you (the 
user) have access to. You use or manipulate user memory when you 
enter an object on the stack, save an object in a variable, delete 

a variable, create an equation or matrix, run a program, etc. In 
addition, the HP 48 periodically performs a system cleanup to free 
memory for use. 


The figure on the next page illustrates how the built-in RAM in the 
HP 48 is organized. Note that the figure is not to scale. 


Memory 5-1 


| System | Available Memory User Memory _ 
' Home ' Port 0 
A) B: c D'E: EF! G ! H 
T ie EE 


Partitions move depending on current allocation of memory 


Schematic view of Built-In RAM in the HP 48 


After a full memory reset, the calculator memory is returned to the 
state it was in when shipped from the factory. The only items stored 
in memory at that point are the built-in system variables (section A). 
All other memory is available memory (C). 


As you work with the calculator, available memory is allocated 
automatically into the various regions shown in the figure above and 
described below: 


m System Memory: This space is reserved by the RPL system. 
You have no direct control of this space. It is divided into 
non-expandable and expandable sections: 


o System Variable Storage (A): Non-expandable section containing 
the values of all RPL system variables (such as PICT) and the 
current locations of the “boundaries” between the remaining 
expandable sections of RAM. 


o Temporary System Storage (B): Expandable section containing 
temporary copies of objects being manipulated and the “return 
stack” (a list of currently pending operations). 


a Available Memory (C): Expandable section containing all 
non-allocated RAM remaining after System and User Memory is 
subtracted from the total configured memory. 


m User Memory: The memory available for your use. User memory is 
further divided into five expandable sections: 


o The Stack (D): Contains the objects currently on the stack. 


5-2 Memory 


oO LAST Variable Storage (E): Contains the three temporary 
variables—LAST CMD, LAST STACK, and LAST ARG—that 
save copies of the previous commands, stack, and arguments so 
that they can be restored if needed. To save memory, you can 
disable these variables (see page 4-10). 


D Local Variables Storage (F): Contains any local variables created 
by currently-executing programs. Local variables exist only while 
the program executes. 


o HOME (G): Contains all named (stored) objects. You can 
organize and control HOME using the Variable Browser (see page 
5-5). Most of the remainder of this chapter describes HOME. 


5 Port 0 (H): Contains backup objects and libraries that you have 
stored in Port 0. 


HOME: Variables and Directories | 


The HOME section of memory works much like a disk does on a 
personal computer. Each named object in HOME, or HOME variable, 
is analogous to a file on a computer disk. 


Like files, HOME variables let you store and retrieve information using 
meaningful names. For example, you can store the acceleration of 
gravity, 9.81 m/s”, into a variable named G and then use the name 

to refer to the variable’s contents. Unless you specify otherwise, all 
variables you create (by name) will be HOME variables. 


Also, like files, HOME variables can be arranged hierarchically into 
directories, and organized to suit your particular needs. Note that 
directory names are stored in variables. 


Only one directory (the current directory) can be active at a time. 
The master directory (or root directory) for the HP 48 is called the 
HOME directory and is, until you change it, the current directory. 
The path of the current directory (the current path) is shown in the 
status area of the display. 
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HOME PROG MATH } 


—H 
4 
3 
ra 
l 


arry [TRIG] O O o o 


You always have immediate keyboard access to the variables stored 
in the current directory. Pressing the key brings up a menu 
(the VAR menu) of the last six variables you stored into the current 
directory. (Pressing steps you through additional “pages” of 
variables.) Since directory names are normally stored in variables, 
they also appear in the VAR menu, with bars over the top-left corner 
(“tabs”) of their menu labels to show that they are directories. 


The HOME directory is the only directory that exists when the 
calculator is turned on for the first time. You create other directories 
as needed using the Variable Browser. 


Where to Store Variables 


When you evaluate a variable, the HP 48 searches the current 
directory for the name of the variable. If the name isn’t there, the 
HP 48 searches up the path until it finds the variable or searches the 
HOME directory. Note that it will evaluate the first variable it finds 
with the designated name, which may or may not be the one you 
had in mind. This suggests several approaches to organizing your 
variables: 


a Put variables that you want to access from any directory into the 
HOME directory. 


a Put variables that you don’t want to be able to access from all 
directories into a directory not on the current path. 


m You can use duplicate variable names, as long as they are not in the 
same directory. 
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Using The | Variable Browser Application 


The Variable Browser is an application designed to facilitate the way 
you view and organize the HOME memory section and the directories, 
subdirectories, and variables in it. 


To select the Variable Browser, press ()(MEMORY): 


DEUECTS iN í HOME 


apse 
ENSTN: 'E=M*C*2' 
PPAR? © €-6.53s-S.13. 


[Ett [cunni CHE] NEH [copy [Move] 


The Variable Browser— Main Screen 


This section describes the tasks you can perform using the Variable 
Browser: 


Creating new variables. 
Selecting variables. 

Editing variables. 

Copying and moving variables. 
Purging variables. 

Finding the size of variables. 


Creating New Variables 


Variable names can contain up to 127 characters, and can contain 
letters, digits, and any characters except these: 


æ Characters that separate obiret space, period, comma, Ë 
m Object delimiters #£ 2" g piam 
w Mathematical function symbols: + ~ # s * 


eto 2aear i 


Note that uppercase and lowercase letters are not equivalent, even 
though they appear the same in menu labels. 


The variable names you use must also follow these restrictions: 


m Names can’t begin with a digit. 
m You can’t use the names of commands (for example, SIN, i, or 7). 
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a You can’t use the name PICT, which is used by the HP 48 to 
contain the current graphics object. 

a Certain names are legal variable names, but are used by the HP 48 
for specific purposes. You can use these names, but remember that 
certain commands use them as implicit arguments: if you alter 
their contents, those commands may not execute properly. These 
variables are called reserved variables: 

c EQ refers to the equation currently used by the SOLVE and 
PLOT applications. 

a CST contains data for custom menus. 

o XDAT contains the current statistical matrix. 

n ALRMDAT contains the data for an alarm being built or edited. 

a XY PAR contains a list of parameters used by STAT commands. 

© PPAR contains a list of parameters used by PLOT commands. 

a VPAR contains a list of parameters used by 3D PLOT 

commands. 

PRTPAR contains a list of parameters used by PRINT 

commands. 

o JOPAR contains a list of parameters used by IO commands. 

oa st, s2, ... , are created by ISOL and QUAD to represent 
arbitrary signs obtained in symbolic solutions. 

conti, n2, ... , are created by ISOL to represent arbitrary integers 

obtained in symbolic solutions. 

co Names beginning with “der” refer to user-defined derivatives. 


J 


To create a new variable from the Variable Browser: 
1. Press (>) (MEMORY). 


2. Select HEM from the menu. 


WHEW VARIABLE 
OBJECT: 
HAME: 
— DIRECTORY 


ENTER NEH OBJECT 


| EmT (cuon | feani] OK | 
The NEW VARIABLE screen 
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3. Enter the new object in the (EJECT: field. You can do this several 
ways: 
w Key the object into the command line and press (ENTER). 
a Use the Equation Writer environment (see chapter 7) to enter an 
algebraic object. 
a Use the Matrix Writer environment (see chapter 8) to enter an 
array object. 
a Press 
a Press (NXT) £ 
stack, and press 
4. Enter a name into the HA 
5. Press DE 


and select an object. 

LE, put the desired object on level 1 of the 
z (see chapter 3). 
Es field (with or without quotes). 


Note that if the variable name you use is too long to fit in a menu 
label, only the beginning of the name will appear in its menu label. 


To create a new subdirectory in the current directory: 
1. Press (>) (EMORY). 


2. Press oO HEM 

3. Press (F) and enter a name into the HAME: field. 

4. Highlight the [DIRECTORY check field, and press {HE (or 
E). 

5. Press GE 


Selecting, Editing, and Recalling Variables 


The Variable Browser makes it easy to select one or more variables 
from any directory, and to perform operations on several variables at a 
time. You can also edit existing variables, and recall variables to the 
stack. 


To select a single variable in the current directory: 


a Press (Ge) (MEMORY). 
m Use the (A) and (F) keys to highlight the desired variable. 


To select a group of variables in the current directory: 


L. Press (G2) (EMORY) 
2. Use the (A) and (¥) keys to highlight one of the variables. Or, press 


(a) and a letter key to highlight the next variable in the current 
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directory that starts with that letter and repeat until the desired 
variable is highlighted. 

3. Press CHE (or press to include the variable in the group 
you're selecting). 

4. Repeat steps 2 and 3 for each additional variable you want. 


Once you’ve marked the variables you want, you can perform an 
operation on the entire group at once. 


To select variables in a different directory (change current direc- 

tory): 

1. Press (Ge) (WEMORY). 

2. Press CHOOSE to bring up the Directory Browser, which shows the 
directories and subdirectories in the HOME memory section. 


EJECTS IM {í HOME + 


ADDS: & + + 2 


ALG: 'AtB' 

B: 3 

Ae 2 

(EMT [CHOOS| CHK] NEE | COPY | MOVE! 


A Typical Directory Browser 


3. Use the (@) and (F) keys (or (œ) and the first letter of the 
subdirectory) to highlight the subdirectory you want, and press 
OE 
4. Select the desired variable or variables. 


To edit a variable: 


1. Press (S) (EMORY). 


2. Select the variable you want to edit. 

3. Press EDIT EDLE. 

4. Edit the object using the Edit environment, and press OE 
Ge when you finish. 
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To recall a variable to the stack: 


L. Press (G6) (EMORY), 


2. Select the variable you want to recall. 


3. Press : 
4. Exit the Browser when done (press (CANCEL)). 


preg 
POEs 


Copying, Moving, and Purging Variables 


The Variable Browser also makes it convenient to arrange your 
variables the way you need. 


To copy variables: 


1. Press (Œ) MEMORY). 


2. Select the variable or variables you want to copy. 


3. Press 


4. Enter one of the following into the COPY Tis field: 


DERT.. 


Z COPY VARIAELECS3 3 


MAME: PPAR 
COPY TO: 


ENTER VAR NAME OR DIRECTORY PATH 
Lett LS fO heaneL| Dk | 


The Copy Variable Screen 


w A new variable name (to store a copy of the selected variable in a 
new name) 
m An existing variable name (to replace the contents of the named 
variable with the selected object) 
a A directory path list (to store a copy of the selected variable 


under the same name but in a different directory) 


5. Press 


Li 
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To move a variable: 


1. Press (ee) (EMORY). 


2. Select the variable(s) you want to move. 
3. Press HOME. 


S MOVE VARIRBLECS 


MAME: PPAR 
MOVE TD: 


ENTER VAR MAME OR DIRECTORY PATH 


The Move Variable Screen 


4. Enter one of the following into the MOVE TO: 
a A new variable name (to rename the selected object) 
a An existing variable name (to replace the contents of the named 
variable with the selected object, and delete the selected object) 
a A directory path list (to move the selected variable to a different 
directory) 
5. Press 0E 


To purge variables: 


1. Press (>) (EMORY). 


2. Select the variable or variables you want to purge. 
3. Press PURI. 


Determining the Size of Variables 


The Variable Browser lets you find how much storage memory a 
variable uses. 
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To determine the size of variables: 


L. Press (G) (MEMORY). 


2. Select the variable or variables that you want to “measure.’ 

3. Press E- from the second page of the menu (press if 
necessary). You will see a message box similar to the one shown 
below: 


SOEJECTS IN {£ HOME 


63 bytes 


UiMem Available: 
Et 125135 bytes 


The SIZE Message Box 


4. Press COE = to remove the message box. 


Using Variables: The VAR Menu 


The VAR menu provides access to the global variables you’ve created 
in the current directory. 


While the Variable Browser is most useful for organizing and 
manipulating the variables you’ve created, the VAR menu is handy for 
using variables in calculations, incorporating them in equations, and as 
a shortcut for a number of common memory tasks: 


m Create a new variable. Put the desired object on level 1 of the 
stack, type the name of the variable, and press (STO). The new 
variable is placed in the current directory and displayed in the VAR 
menu. 


m Evaluate a variable. Press the variable’s VAR menu key. 


m Recall the contents of a variable to the stack. Press (@) followed by 
the variable’s VAR menu key. 


a Recall the name of a variable to the stack. Press C) followed by the 
varlable’s menu key. 


Memory 5-11 


Update the contents of a variable. Put the newly edited contents of 
the variable on stack level 1 and press () followed by the variable’s 
menu key. 


s Purge a variable (name and contents) from memory. Recall the 


name of the variable to the stack and then press ($) (PURG). 


a Purge a group of variables at once. Put a list (with £ 3 delimiters) 
containing the unquoted names of the variables to be purged on 


stack level 1, and press (|) (PURG). 


Include the name of a variable in an algebraic or program. 
Assuming that the appropriate quote marks are already entered 
(tick-marks for algebraics or guillemots for programs), press the 
variable’s VAR, menu key. 


a Switch to the HOME directory. Press (-®)(HOME). 
a Switch to the parent directory. Press ()(UP). 


Example: Explore the use of the VAR menu using a variable named 
OPTION containing 6.05. 


Step 1: Create the variable, OPTION and display the VAR menu. 


6.05 BOO kem O T CO T 
OPTION (o) 


Step 2: Recall the value of the variable. 


OPTIC 1: 6.85 
memo O a a 


Step 3: Recall the name of the variable. 


aen e e 


Step 4: Change the value in OPTION to 6.15. Recall the contents 
again to confirm the change. 


6.15 HETIG a: 6.65 
GPT E S: ' OPTION, 
m O T AA 
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Step 5: Clear the stack and purge OPTION from memory. 


l: 


Defining Variables 


The HP 48’s DEFINE command can create variables from equations 
(see chapter 7 for information about creating equations). If stack level 
1 has an equation with this form, 'name = expression', executing 
DEFINE stores that expression in that name. 


To create a variable from a symbolic definition: 


1. Enter an equation of the form 'name = expression'. 


2. Press ()(DEF) (the DEFINE command). 
Example: Use DEFINE to store M*C? in the variable £. 


Step 1: Press QV@Q@MEM)E)M™&)C@) 2 (ENTER). 
Step 2: Press (#,)(DEF). 


Note that if flag —3 is clear (its default state), DEFINE stores the 
expression without evaluation. If you've set flag —3, the expression to 
be stored is evaluated to a number, if possible, before it’s stored. For 
example, the keystrokes 'R=18+18' (|)(DEF) create variable A and 
store '18+14' in it if flag —3 is clear, and Z6 if flag —3 is set. 


Evaluating Variables 


To use a variable’s contents in a calculation, the variable must be 
evaluated. This is accomplished by pressing the variable’s menu key in 
the VAR menu. 


Evaluating a variable name calls the object stored in the variable: 


w Name. The name is evaluated (calling its object). 

a Program. The program runs. 

m Directory. The directory becomes the current directory. 

m Other Object. A copy of the object is returned to the stack. 


Example: Suppose that there are four variables in the current 
directory—-A containing 2, B containing 3, ALG 
containing the expression ‘A+E', and ADD2 containing 
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the short program # + + #. Evaluate them from the VAR 
menu. 


Step 1: From the stack, display the VAR menu. 


VAR es 
1: 
MHN 


Step 2: Evaluate ALG, B, and A. Because none of these variables 
contain programs or directories, their contents are put on the 
stack. 


3 "A+B! 
J 


jabba} Abe | e | a O 


Step 3: Evaluate ADD2. Notice that the program is executed, not 
merely put onto the stack. 


RDU D: 
1: 'A+B+?! 
CD e lal T 


Quoted Variable Names and Formal Variables 


The ' delimiter is very important when you enter a variable name: it 
determines whether the name is automatically evaluated when you 
press (ENTER). If the ' delimiter is present, the name is not evaluated. 


To enter a variable name onto the stack: 


m Ifa variable with that name exists (or might exist), press (1), then 
type the name or press its VAR menu key. Variable names included 
as a part of an algebraic expression are within quotes and are not 
evaluated until the algebraic is evaluated. 

a If no variable with that name exists, type in the unquoted name and 
press (ENTER). Because the HP 48 can’t find an object associated 
with the new name, the name is treated as a formal variable and 
put on the stack with quotes. Evaluating a formal variable simply 
returns the formal variable name again. 
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Although they appear identical on the stack, there are two important 
differences between formal variable names (that have no associated 
objects) and quoted variable names (that have associated objects): 


a Evaluating a formal variable doesn’t appear to do anything, because 
the formal variable is returned again to the stack. Evaluating the 
quoted name of a variable containing an object evaluates that 
object. 


wa Formal variables never appear in the VAR menu. All variables that 
appear in the VAR menu have an associated object. However, you 
can store a formal variable name in a VAR variable with a different 
name. 


Example: Enter the name * onto the stack using single-quotes. 


ADD2 (ENTER) 1: "ADDS | 
O@@ ENTER Abbe ALG | e dal T 1 


Example: Enter the formal variable name, È, onto the stack by 
using the unquoted name. If an actual variable, & exists 
somewhere in the current path, you will see its contents 
instead of the variable name. 


(a) C (ENTER 1: igi 
paboet ata | Ft at 


Example: Store the formal variable ‘' in the variable C2. Then 
evaluate 22 using the VAR menu. 


Step 1: Store ‘Et'in C2. 


(4) (CLEAR) (p>) (MEMORY) l: 


H @) C (ENTER) @) C [ce ee 
ENTER BHE NXT DE 
Step 2: Evaluate ČZ using the VAR menu. Confirm that '' isa 
formal variable by pressing (EVAL). 
VAR l: i C i 
ca [aoe j aLa | e pado 
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Special Memory Operations 


Occasionally the HP 48 may seem to freeze while executing something, 
and won’t respond to the key. This can happen if the 
memory becomes corrupted, or if the system becomes “confused” 
during execution. 


If this happens, you have two ways to try to correct it: a system halt 
and a memory reset. 


If you must reset your calculator, always attempt a 
system halt first. Consider a memory reset. only if 
the system halt fails. 


Caution 


System Halt 
A system halt does the following: 


a Interrupts and cancels all executing programs and system 
operations. 

m Clears the stack, all local variables, the three LAST variables, the 
PICTURE display, and the temporary system storage section of 
memory. 

m Turns off the user keyboard (clears flag -62). 

m Detaches all libraries from the HOME directory, and reconfigures all 
libraries in all available ports (see “Using Libraries” in chapter 28 
for details). 

m Makes the HOME directory the current directory. 

m Activates the main MTH menu. 


Note that a system halt does not affect the stored objects in HOME 
and Port 0. 


To halt the system from the keyboard: 


1. Press and hold (ON). 
2. Press the menu key. 
3. Release both keys. 


A system halt is also performed automatically when you turn on the 
calculator if you have added, removed, or changed the write-protect 
switch position of any plug-in card since you last turned the calculator 
on. 
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Sometimes the HP 48 may freeze up and won’t respond to 
because it isn’t accepting input from the keyboard. At these times, 
you need to execute the system halt directly, without using the 


keyboard. 


To halt the system without using the keyboard: 


1. Turn the calculator over and remove the top right (as you face the 
back side of the machine) rubber foot. You should see a small hole 
with the letter R next to it. 


rit 


_eonstoeectoneensseaseabrtseentiit 
Matalassos 


| 

| 

| 

| { © 32k/128K ONLY ) 

| ( \ Re 


® 


— ~~~ Reset hole 


2. Insert the end of an ordinary metal paper clip into the hole as far 
as it goes. Hold for one second and remove. 


3. Press (ON). 
4. If necessary, press (ON}(C). If this still doesn’t work, you need to 


try a memory reset. 


Memory Reset 


A memory reset can reset the HP 48 to its factory-default state, 
erasing all information you've stored. Use this function very carefully. 


To perform a memory reset: 


1. Press and hold down these three keys simultaneously: (ON), the 
menu key, and the menu key. 

2. Release the two menu keys, but continue to hold (ON): 
a If you want to continue with the memory reset, release (ON). 
m If you want to cancel the memory reset, press the menu key, 


then release (ON). 
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Once you’ve initiated the memory reset, the calculator beeps and 
displays the following screen: 


Try To Recover Memory? 


Memory Reset Prompt 


3. Press * if you want to try and recover the variables you 
have stored in HOME and in Port 0. There is no guarantee 
that all of the variables can be recovered. Press = HĒ- to 
perform a complete memory reset. This restores the HP 48 to its 


factory-default state and clears all user memory. 


Responding to Low-Memory Conditions 


HP 48 operations share memory with the objects you create. This 
means that the calculator may operate slowly or even fail if user 
memory becomes too full. If this happens, the HP 48 returns one of a 
series of low memory warnings. These messages are described below in 
order of increasing severity. 


g Ho Boon for Last tack—TIf there’s not enough memory to save 
a copy of the current stack, this message appears when ENTER 
is executed. The UNDO operation is disabled when this message 
appears. 


Remedy: Delete unused variables or unnecessary objects from the 
stack. 


m in fizie emg This appears if there isn’t enough 
memory to completely execute an operation. If the LASTARG 
command is enabled (flag —55 is clear), the original arguments are 
restored to the stack. If LAST ARG is disabled (flag —55 is set), 


the arguments are lost. 


Remedy: Delete unused variables or unnecessary objects from the 
stack. 


5-18 Memory 


i 4 -: —This message appears when the HP 48 
coraletes all loade TS but doesn’t have enough free 
memory to display the stack. When this occurs, the stack displays 
objects only by type: Feal Humber, Algebraic, and soon. The 
amount of memory required to display a stack object varies with the 
object type. 


Remedy: Delete unnecessary variables and unneeded objects from 
the stack, or store stack objects in variables so they don’t have to be 
displayed. 


Dark o ¢—In extreme cases, the calculator runs completely 
out of memory and is unable to do anything. In this situation you 
must clear some memory before you can continue. The HP 48 


activates a special procedure to do this, and shows this display: 


Out of Memory 


Purge? 
1: Real Array 


When the procedure starts, the HP 48 asks whether you want to 
purge the object (described by object type) in level 1 (a real array 
in the above figure). If you delete it, the calculator then asks about 
the new level 1 object. This continues until the stack is empty or 
you respond to the display by pressing HO. The calculator then 
asks if you want to discard the contents of LAST CMD, and then 
asks in the following order if you want to delete other items: 


1. Stack level 1 (repeated) 

. The contents of LAST CMD 

The contents of LAST STACK (if active) 
The contents of LAST ARG (if active) 
The variable PICT (if present) 

Any user-key assignments 

Any alarms 

The entire stack (unless already empty) 
Each global variable by name 

Each port 0 object by tagged name 


Wh 


Se OA OS Chas 


= 
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To respond to the “Out Of Memory” prompts: 


m To delete the indicated object, press ¥ES 
a To keep the indicated object, press = HO 
= To stop the procedure and see if the condition is fixed, press 


(CANCEL) 


Note The purge sequence may begin with the command 

line and then cycle through the stack, the contents 
l of LAST CMD, etc. If you answer Hf to the 
purge prompt for the command line, you'll return to 
the command line when you terminate the Gut of 
Memory procedure. 


The prompts for global variables start with the newest object in the 
HOME directory and proceed to successively older objects. If the 
variable to be purged is an empty directory, YES purges it. If the 
directory is not empty, YES- cycles the variable-purge sequence 
through the variables (from newest to oldest) in that directory. 


Whenever you like, you can try to terminate the Gut of Memory 
procedure by pressing (CANCEL). If sufficient memory is available, the 
calculator returns to the normal display; otherwise, the calculator 
beeps and continues with the purge sequence. After cycling once 
through the choices, the HP 48 attempts to return to normal 
operation. If there still is not enough free memory, the procedure 
starts over. 
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Input Forms and Choose Lists 


Although the HP 48 screen is small compared to a standard computer 
screen, it is approximately the size of the average “dialog box.” Input 
forms are the HP 48 equivalent of these dialog boxes. 


Most of the HP 48’s applications have input forms associated with 
them that make it easy to remember the information you need to 
enter, and to set any options you want. 


Input Forms 


All input forms have a similar appearance. The figure below uses the 
main input form from the PLOT application to illustrate the main 
components, 


S, $$ PLOT 
TYPE: Function : 
w DEE 
INDEF: WO H-YEW: -6,5 6.5 
ÁUTOSCALE V-VEW: -3,1 3.2 


EMTER FUMCTION(S) TO PLOT 
EMT {CHOOS| | OPTS [ERASE URAH 


A Sample Input Form: PLOT 


Each input form has a title, a set of fields (some with labels) a prompt 
line (just above the menu), and a menu that displays choices relevant 

to the currently selected field (the prompt line also displays a message 
pertaining to the current field). As you switch fields, the prompt and 

the menu change to reflect the newly-selected field. 
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Input forms use four basic kinds of fields: 


Data fields. These accept data of a particular kind directly from the 
keyboard. The fields labeled THDEF:, H-¥IEM:, and V-VTER in 
the PLOT form are examples of data fields. 

Extended data fields. These fields extend the abilities of data fields 
by also allowing you to enter an object you have previously stored 
(as long as it is an allowable type for that field). The Et: field in 
the PLOT form is an example of an extended data field. 
List fields. These fields have a limited, pre- determined set of possible 
values, of which you must choose one. The TYFE! and 2? fields in 
the PLOT form are examples of list fields. 

Check fields. These fields control various options in the applications 
(a check in the field makes the option active). The Fl E field 


` in the PLOT form is an example of a check field. 


Selecting Fields in Input Forms 


The cursor keys are active in input forms and are the primary means 
of selecting fields: 


œ) Selects the next field, moving from left to right and from 


top to bottom. From the last field on the form, (>) “wraps 
around” and selects the first field at the top of the form. 


a) Selects the previous field. From the first field on the form, 


(4) “wraps around” and selects the last field at the bottom of 
the form. 


(a) Selects the corresponding field on the previous line. From a 


field on the top line of the form, (A) “wraps around” and 
selects the corresponding field on the bottom line of the 
form. 


(VW) Selects the corresponding field on the next line. From a field 


on the bottom line of the form, (F) “wraps around” and 
selects the corresponding field on the top line of the form. 


NA Selects the first field on the form. 
()(@) Selects the first field on the form. 
E)E) Selects the last field on the form. 
()(¥) Selects the last field on the form. 
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When you press (ENTER) or iE to enter data that has been 
typed into the command line, the next field is automatically selected. 
Otherwise, you must move the selection bar using the cursor keys. 


Entering Data in Input Forms 


The HP 48 provides several ways to enter data into input forms. 


To enter information into a data field: 


l. 
2 


Select the data (or extended data) field. 

Type in the object. The command line is available for all kinds of 
objects (remember to use the proper delimiters, however). You can 
also use the EquationWriter for algebraic objects (see chapter 7), 
or the MatrixWriter for arrays (see chapter 8). To change to the 
Equation or Matrix Writer, see “To make a side-trip to a second 
input form” on page 6-5. 


. Press (ENTER) or 9 GE 


To enter a previously stored object into an extended data field: 


1. 
2. 


3. 


4, 
S 


Select the extended data field. 

Press (HOOS. A miniature version of the Variable Browser 
appears, containing all variables in the current directory that can 
be used by the selected field. 

Use the (A) and (F) arrows to highlight the object you want. 


Press (ENTER) or o GE 


ome extended data fields also allow you to enter multiple objects, 


grouped into a list. 


To enter a list of objects into an extended data field: 


. Press i 


. Select the extended data field that accepts list objects. 


. A miniature version of the Variable Browser 
appears, containing all variables in the current directory that can 


be used by the selected field. 


. Use the (A) and (F) arrows to select an object that belongs in the 


list. 
Press s to display a check-mark next to the object. 
Repeat steps 3 and 4 for the other objects in the list. 


. Once all objects in the list have checks, press or 
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Selecting Options in Input Forms 


To select an option from a list field: 


1. Select the list field. 
2. Select an option for that field using one of the following methods: 
m Use a pop-up list. 
a. Press HOGS to bring up a pop-up lst of available options. 


F: 
inpe|Parametric 


SOLK Diff Eq 
Conic 


A Sample Pop-Up List: PLOT Types 


b. Use the (Æ) and (F) arrow keys to select an option. 
c. Press or OE 

a Press repeatedly to cycle through the options. Stop when 
the option you want appears. 

m Press (@) followed by the first letter of the desired option. The 
next option beginning with that letter appears. If more than one 
option begins with the same letter, you may have to repeat. the 
procedure once or twice until the option you want appears. 


To select an option in a check field: 


1. Select the check field. 

2. Do one of the following: 
m Press {HE once or twice to check or uncheck the field. 
m Press once or twice to check or uncheck the field. 


Other Input Form Operations 


To edit a data field: 


1. Select the data (or extended data) field. 
2. Press T (or ()(EDIT)). This copies the object into the 


command fine: 
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3. 


4. 


Edit the object using the standard command line editing 
procedures. 


Press (ENTER) or = GE 


To make a “side” calculation while in the input form: 


1. 
2: 


or 


Select the data (or extended data) field. 

Press CALE. A version of the stack appears (notice that 
both the form title and the field prompt are still visible), and any 
object. that was in the selected field is now on level 1. If desired, 
press T° to show or hide the status line. 

Perform the stack calculation you need, entering additional objects 
or selecting commands from other menus. The result you want to 
enter into the data field must be on level 1 when you finish. 


_ If i isn’t visible on the menu (because you have used other 
menus), press (€)(CONT) to make it visible again. 

. Press © GE to enter the calculated result into the selected data 
field, or SAHEL to return without entering the result. 


To make a “side-trip” to a second input form: 


~~ 


. Select a data (or extended data) field. 
. Press CALE. A version of the stack appears (notice that 


both the form title and field prompt are still visible), and any 
object that was in the selected field is now on level 1. 

Open the second input form. 

Complete your task(s) in the second input form and exit it by 
pressing E or ANCL, or by executing a task that exits that 
particular form. 


. If BES isn’t visible on the menu (because you have used other 


command menus), press (€)(CONT) to make it visible again. 


. Make sure the object on level 1 of the stack is what you want 


stored in the selected data field of the original form. (It may have 
changed, depending on what you did in the second input form.) 
Press E> to return to the original input form and enter the 
level 1 object into the selected data field in the input form, or 

oF i to return without entering the level 1 object. 
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To reset the value of a field to its default: 


1. Select the field. 

2. Do one of the following: 
a Press RESET. 
a Press 


3. Select £ 


4. Press (ENTER) or 


To reset the values of all fields to their defaults: 


ie) from the pop-up list. 


w 
a 


1. Select a field. 
2. Do one of the Pa 
m Press ET 
w Press 


3. Select Reset a11 from the pop-up list. In some applications 


(PLOT is ae the phrasing will differ slightly, because one or 
more fields must be reset individually (as a precaution against 
unintentional data loss). 


4. Press (ENTER) or OE 


To determine which object types are valid for a data field: 

1. Select the data (or extended data) field. 

2. Press (NXT) T¥FES. A pop-up window display the types of objects 
you can use in that field. 


F: 
InvE| Ž ETE $ 


SOLb Name 
Real number 


A Sample TYPES Pop-Up List 


3. Do one of the following: 

m To begin entering a particular data type, select the type in the 
pop-up list and press HEH. The appropriate delimiters appear 
in the command line. 

m If you don’t want to enter data, press OF. 


6-6 Input Forms and Choose Lists 


When You Finish Entering Data into an Input Form 


Input forms are designed to help you enter data and prepare to 
execute a larger task. The data you enter and options you select may 
either be used only within the context of the particular input form and 
its tasks, or they may cause global changes throughout all applications. 
Changes to reserved variables (such as EQ) and system flags are 
examples of global changes. 


Whether or not these global changes are saved depends on how you 
exit the input form. The following procedures illustrate your options: 


To execute the main action of an input form: 


1. Make sure the necessary data is entered and proper options 
checked. . 

2. Press the appropriate action key (particular to each form). 
Global changes are saved and the action executed, displaying the 
appropriate screen. This does not usually cause you to exit the 
input form. 


To exit the input form after saving any global changes: 

m Press GE from the menu. Sometimes it is shown only on the 
second page (press (NXT), if necessary.) 

To exit the input form and discard any global changes: 

a Press or CAKL. Sometimes AHEL is shown only on the 
second page (press (NXT), if necessary.) 

To exit SOLVE input form and open PLOT input form (and vice- 

versa): 


m Open the new input form. Global changes are saved and all 
non-global data is discarded before the current input form is exited 
and the new input form opened. 


Input Form Commands 


The HP 48 has several programmable commands you can use to create 
your own customized input forms. These commmands, located in the 
PRG IN command menu, are discussed briefly in appendix G, and in 
detail in the HP 48G Series Advanced User’s Reference. 
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To create an input form: 


1. Enter a title string for the input form (use (>)(*)). 

2. Enter a list of field specifications. If more than one field is 
specified, enclose each field specification in brackets. 

3. Enter a list of format options. 

4. Enter a list of reset values (values that appear when #E 
pressed). 

5. Enter a list of default values. 

6. Execute the INFORM command. 


Example: Create an input form. 


Enter a title, a field specification, format options, a blank list 
for reset values, and a default value. 


OMNO FIRST 
ONE (ENTER) oO MCa 
O@QNH@ ane) 
QQ 1&5 
GER) © cal) 
OC) @ @ WENDY 


ENTER 


IN LHFOR 
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The EquationWriter 


The HP 48 features the EquationWriter application, which makes it 
easy to enter and review algebraic expressions and equations in the 
form most familiar to you—the way you usually see them in print, and 
the way you write them with pencil and paper. 


For example, here’s a physics equation: 


te 
cams f a dt 
ti 


Here’s how the equation would look on the stack: 


AAPELI tamti! 


Now, here’s the same equation keyed in using the EquationWriter 
application: 


t2 
v=vðe | adti 
ti 


[VECTRA] HATR| LIZT | HYP | REAL | BASE | 
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Organized 


In the EquationWriter application, keys corresponding to algebraic 
functions enter the function name or graphical function symbol into 
the equation. For example, pressing draws a square root sign. 
You can display any command menu—however, only those keys that 
correspond to algebraic functions are active. Like the function keys 
on the keyboard, the menu keys don’t execute the corresponding 
function—they simply enter the function name into the equation. 


The EquationWriter application consists of three modes, each with a 
special purpose: 


a Entry mode—for entering and editing equations 
w Scrolling mode—for viewing large equations 
m Selection mode—for editing expressions within equations 


A+ 


Mico 


WECTR MATE] LIST | HYP [REAL | EASE | 
Entry Mode Scrolling Mode 


RULES] EDIT | EXPR | SUE | REPL 


Selection Mode 
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To start the EquationWriter application: 
m Press ()(EQUATION). The EquationWriter is accessible from the 


stack or from any field in an input form that can accept algebraic 
objects. 


After you start the EquationWriter application, you can enter an 
equation or expression (or unit object, number, or name) using the 
operations available in this environment. See “Entering Equations” 
below. 


To exit the EquationWriter application: 


m To put the equation on the stack and exit, press (ENTER). 
m To discard the current equation and exit, press (CANCEL). 


Entering Equations 


Occasionally the EquationWriter may not be able to display your 


equation as fast as you type it. However, you can continue typing, and 
the HP 48 will remember up to 15 keystrokes and display them when 


it “catches up.” 


To enter numbers and names: 


m Key numbers and names in exactly as you would into the command 


line. You can also use the menu keys in the VAR menu as typing 
aids for variable names. 

To include addition, subtraction, and multiplication: 

ma To enter +, ~, and *, press G), ©), and (x). 


a To do implied multiplication, don’t press (x). You can do implied 


multiplication (without pressing (x)) in some situations—-a multiply 


sign (*) is automatically inserted between the following: 

o A number followed by an alpha character, a parenthesis, or a 
prefix function (a function whose argument(s) appear after its 
name)~~for example, press 6 (SIN). 

An alpha character and a prefix function—for example, A 
Qe). 


o A right parenthesis followed by a left parenthesis. 
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ci A number or alpha character and the divide bar, square-root 
symbol, or xth root term—for example, B (a). 


Note All multiplication (even implied multiplication) 
should display a multiplication operator (# or +). In 
particular, an expression such as #¢''+2Z% contains 
no multiplication. The form, € 2, is a user-defined 
function (see page 11-6), whose parentheses 

contain its Broun By contrast, expressions 

such as # ; “egy do include valid 
multiplications. 


To include division and fractions: 


1. Press (A) to start the numerator. 

2. Press (>) to end the numerator and start the denominator ((¥) 
works too). 

3. Press (œ) to end the denominator. 

Here’s another way to type in fractions whose numerator consists of 

either one term or a sequence of terms with operators of precedence 

greater than or equal to that of division: 


1. Type the numerator (without pressing (@)). 

2. Press (=) to start the denominator. 

3. Press (œ) to end the denominator ((¥) works too). 
To include exponents: 

1. Press to start the exponent. 

2. Press (®) to end the exponent ((¥) works too). 

To include roots: 


a To include a square root, press to draw the | symbol and start 
the term, then press (®) to end the term. 

m To include an rth root, press ()(W) to start the x term (outside 
the J symbol), press D to draw the 7 symbol and start the y term 
inside the F symbol, then press (>) to end the rth root term. 


To include functions with parenthetical arguments: 


1. Press the function key, or type the name and press ()(()). 
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2. Press (>) to end the argument and display the right parenthesis. 


To include parenthesized terms: 


1. Press (¢4)(()) to display the left parenthesis. 
2. Press (>) to end the term and display right parenthesis. 


To include powers of 10: 


1. Press to display E. 
2. If the power is negative, press to display ~. 


3. Key in the digits of the power. 
4. Press any function key to end the power. 


To include derivatives: 


1. Press ()(6) to display 2, 

2. Key in the variable of differentiation, then press (®) to end the 
differentiation term and display the left parenthesis. 

3. Key in the expression. 

4. Press (>) to end the expression and display the right parenthesis. 


To include integrals: 


1. Press (>) to display the integral symbol s with the cursor 
positioned at the lower limit. 

2. Key in the lower limit and press (>). 

3. Key in the upper limit and press œ). 

4. Key in the integrand and press (>) to display d. 

5. Key in the variable of integration. 

6. Press (>) to complete the integral. 


To include summations: 


1. Press (œ)@Œ) to display the summation symbol = with the cursor 
positioned below. 

2. Key in the summation index. 

3. Press (>) (or ()G)) to key in the equal sign. 

4. Key in the initial value of the index and press (>). 

5. Key in the final value of the index and press œ) 

. Key in the summand. 

. Press (>) to end the summation. 


“Im 
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To include units: 


1. Key in the number part. 

2. Press ()() to start the unit expression. 
3. Key in the unit expression. 

. Press (®) to end the expression. 


a 


You can also build unit objects (described in chapter 10) in the 
EquationWriter application. For compound units, press (x) or E) to 
separate each individual unit in the unit expression. You can key in 
unit names in one keystroke by pressing the corresponding menu key 
in the UNITS Catalog menu. 


To include | (where) functions: 


1. Key in a parenthetic expression with symbolic arguments. 

2. Press (4)(SYMBOLIC) (NXT) i to display |. The cursor is 
positioned at the bottom right of the symbol. 

3. Key in the defining equation for each argument, pressing (>) or 
(#4) (S) to key in =, and to key in the separator between each 
equation. 

4. Press (>) to end the function. 


The | (where) function substitutes values for names in expressions. It’s 
described under “Showing Hidden Variables” on page 20-17. 


Controlling Implicit Parentheses 


Implicit parentheses are turned on whenever you start the 
Equation Writer application. This means the arguments for =), Ge), 
and are normally enclosed in “invisible” parentheses, so that only 


(œ) (or (¥)) ends the argument. 


If you turn off implicit parentheses, the argument ends when you enter 
the next function—or press (>). 


To turn implicit parentheses on or off: 


m Press (4)((3). A message briefly displays the current state. 


Disabling implicit parentheses is convenient for entering polynomials, 
for example, where exponents are completed when you enter the 
function that starts the next term. 
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Leaving and then restarting the EquationWriter application turns 
implicit parentheses on. If you turn off implicit parentheses after 
keying in ©), Gx), or Q7), but before supplying the argument, implicit 
parentheses are not applied to those arguments. 


Example: Key in the expression X? + 2X? — 4, first with implicit 
parentheses and then without. 


Step dl: Key in the expression with implicit parentheses on (the 
default). 


(CDEUATION) (a) X G7) 3 A 
G)2@X G2) 
O!@Q@x*x 


Step 2: Clear the display and turn off implicit parentheses. 


(&) GEAR) 
aq 


Implicit ©) off 


0 


WECTRIMATR] List | HYP | REAL | BASE | 


Step 3: Key in the expression again. 


QOXE])302@QxE20 
OOX 


Press (|) C} to turn on implicit parentheses again. 
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EquationWriter Examples 


At the end of each of the following examples, you can either press 


(ENTER) to put the equation on the stack, or press (+D (CLEAR) to clear 
the display for the next example. If you do the latter, ignore the 


(4) (EQUATION) instruction at the start of each new example. 


If you make a mistake while you’re keying in an equation, press (¢) to 
backspace to the error, or press (@)(CLEAR) and start again. 
Example: Key in this equation: 

x34yiaa® 
Step 1: Key in the equation. 


DETAN) 

@X0)2 03008 
Drm EDHE |X 
Bia? Oa? 


[VECTRA MATR] LIST | HYP | REN 


Example: Key in this expression: 


i 2T -2 
x? - 2XY coss +Y 


CVEN) 
MxM GO 2 TN | ue 
2 @X eY (cos) i -euv cos St | ay o 


2@N@ 1S) &) 
QOYA: 


Example: Key in this expression: 


[VECTR|HATR]| LIZT | HYP | REAL | EASE | 


d 
WY += 2cos° (TX 
Yox cos*(7X) 
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(4) EQUATION) 


OOS sFàlecosaw Jo 
TOORA 
OA 


ECTRMATE] LIT | HYP | REAL [BASE | 


Example: Key in this expression: 


DETON 
D A 
@OxXM@P O12 
oHG 
SONHO) 
OOO 


Example: Key in this expression: 


kgs 
1.65 x 1971288 
S 


DEAT 
1.69 EICO 2O 
CANTS) MASE EG 


2 
1656-12 428 p 
(@) UNITS) AREF 


5 


i 


Bits ce a a 
TSE. MENES 8 e A Ten e ae 


Editing Equations 
The Equation Writer application provides several options for editing 
equations: 


Backspace editing 

Editing a full expression in the command line 

Editing a subexpression in the command line 

Inserting an object (subexpression) from the stack into the equation 
Replacing a subexpression with an algebraic from the stack 
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To edit by backspacing: 


1. Press (#) until you delete the error. 
2. Complete the expression correctly. 


To edit the full equation: 


1. If the equation ends in an incomplete subexpression, complete it. 


. Press (4) (EDIT). 


2 

3. Edit the equation in the command line. 

4. Press to save the changes (or press to discard 
them) and return to the EquationWriter application. 


To view a large equation or unit object: 


1. Press (4))(PICTURE) to activate scrolling mode. 


2. Press (€) (©) (A) (F) to move the viewing “window.” 
3. Press (44)(PICTURE) to return to the previous mode. 


Editing with Subexpressions 


The Selection environment is a special part of the Equation Writer 
application used to specify a subexpression in the equation. 


A subexpression consists of a function and its arguments. The function 
that defines a subexpression is called the top-level function for that 
subexpression. The top-level function is essentially the last function to 
be evaluated following the usual rules of ete precedence. 


For example, in the expression 'A+B#C-0', the top level function for 
the subexpression ‘+t is #, the top- Gi function for ‘BeteD! is 
~, and the top level function fon Atbetet! 


“fi! is +. You can specify an 
individual object (a name, for example) as the ee. 


You can also use the Selection environment to specify a subexpression 
to rearrange using the Rules transformati “Manipulating 
Subexpressions” on page 20-19. 


To edit a subexpression of an equation: 


1. If the equation ends in an incomplete subexpression, complete it. 

2. Press (€) to activate the Selection environment. 

3. Press (A) (¥) (4) (@) to move the selection cursor to the top-level 
function for the subexpression you want to edit. 
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4, Optional: Press Fat any time to highlight the current 
subexpression. (Press it again to turn off the highlight.) 
5. Press J 


to put the current subexpression in the command 
line. 

6. Edit the subexpression in the command line. 

Press to enter the revised subexpression into the equation 

(or press to discard it). 

8. Press ETT. to leave the Selection environment. (If = 
displayed, press (©) to return to the Selection menu.) 


isn’t 


To insert an object from level 1 into an equation: 


1. Create the object to be inserted and put it on level 1. The object 
can be a name, a real number, a complex number, an algebraic, or 
a string. 

2. Open the EquationWriter and begin creating the equation. 

3. Press (¢®)(RCL) to insert the level 1 object at the cursor in the 
Equation Writer expression. 


Example: Enter this expression: 


10 pa 
| r? — ydr + ~ 5 y 


JO 


Step 1: Enter the expression '#2~''' into level 1 and duplicate it. 


O@ x @)2O@Y W jz: yap 


1 i MA a I 
Hotman a 


Step 2: Select the EquationWriter application and key in the integral 
sign and limits of integration. 


CEN) 
HOI) 106) 
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Step 3: Insert the integrand into the expression. 


(Rc) 


14 
| wv 
a 


ECTRIMATE] LIST | HYP | REAL | ASE | 


Step 4: Complete the subexpression. Then key in the remainder of 
the expression, inserting the second term from the stack. 


01010 


OAMRD 2) iG 2 wes 
| s Yda tagen 
4 
[VECTRA MATA] LIST [ HYP | REAL | 


To replace a subexpression with an algebraic from level 1: 


1. If the equation ends in an incomplete subexpression, complete it. 

2. Press (4) to activate the Selection environment. 

3. Press (A) (¥) (4) Œ) to move the selection cursor to the top-level 
function for the subexpression you want to replace. (See “Editing 
with Subexpressions” on page 7-10.) 

4. Optional: Press EXFR any time to highlight the associated 
subexpression (press EXFR again to turn the highlight off). 

5. Press F 

6. Press ER 


IT to leave the Selection environment. 


The algebraic is deleted from the stack. 
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Operations in the EquationWriter Application 


Description 


SPC 


(&) PICTURE) 


QED 


STO 


Starts a numerator. 


Ends a subexpression. (>) œ) or (>) (F) ends all 


pending subexpressions. 

Invokes selection mode, in which the Selection 
environment is active. 

Starts a parenthesized term. (>) or (F) ends the term. 


Enters the current separator (a or į) for multiple 
parenthetical arguments of functions and the terms of 
complex numbers. 

Exits the EquationWriter application and evaluates 
the equation. 

Returns the equation to the stack and exits the 
EquationWriter application. 

Exits the EquationWriter application without saving 
the equation. 

Toggles scrolling mode. In scrolling mode, the menu 
keys are erased; if the equation is larger than the 
display, (A) (¥) (€) Œ) scroll the display window over 
the equation in the indicated direction. Press 

(#) (PICTURE) again (or (CANCEL)) to return to the 
previous mode. (Exception: Pressing (¥) with an 
algebraic on the stack, starts the Equation Writer in 
scrolling mode and when you exit—with or 
(4) PICTURE}—you invoke the selection mode.) 

In entry mode, returns the equation to the command 
line for editing. 

Returns the equation to the stack as a graphic object. 
(See chapter 9 for more details about graphic 
objects.) 
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Operations in the EquationWriter Application (continued) 


Key Description 


CLEAR) | Erases the display without leaving the 
8 
EquationWriter application. 
()(RCL) Inserts the level 1 object into the equation at the 
cursor position. (See “Editing Equations” on page 
7-9.) 
{} Turns implicit parentheses mode off. Press {} 
P P 
again to turn implicit parentheses mode back on. 
(See “Controlling Implicit Parentheses” on page 7-6.) 
Returns the equation to the stack as a string. 
© 
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The MatrixWriter 


The HP 48’s MatrixWriter application provides you with 
extensive capabilities for entering and manipulating arrays (both 
one-dimensional matrices and two-dimensional matrices). 


The stack displays arrays as numbers within nested E ł delimiters. A 
pair of E ł delimiters enclose the entire array, and additional pairs 
enclose each row within the matrix. For example, here’s a 3 x 3 
matrix as it might appear on the stack: 


re i223] 
E343] 
Eor ggd 


Vectors (also called column vectors or one-column matrices) appear on 
the stack as numbers within a single level of E I delimiters: 


Ce4e6 8 7] 
Row vectors (one-row matrices) appear on the stack as numbers 
within two pairs of E 7 delimiters: 


S ee Se a 4 
T e S ia 


In addition, the current coordinate mode and angle mode affect 
how 2-dimensional and 3-dimensional vectors are displayed. See 
“Displaying 2D and 3D Vectors” on page 13-1 for details. 
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The MatrixWriter application provides a special environment for 
entering, viewing, and editing arrays. You can access the Matrix 
Writer by selecting it from the stack or from any field in an input form 
that accepts array objects. 


The MatrixWriter display shows array elements in individual cells 
arranged in rows and columns. 


Columns 


ae Seta 


Cell ~ Cell Cursor 


coordinate ~~ 


EDIT | VEC m] +410 | HID 


To enter a matrix using the MatrixWriter application: 


eGo ke 


Press (->) (MATRIX). 
Key in the numbers in the first row, and press (ENTER) after each. 


Press (¥) to mark the end of the first row. 

Key in the numbers in the rest of the matrix, and press 
after each. Notice that when you enter the last number in the row, 
the cursor automatically moves to the beginning of the next row. 

. After you’ve entered all the numbers in the matrix, press 


to put the matrix on the stack. 


Example: Enter this matrix: 


2 —2 0 
1 0 3 
-3 5 1 
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Step 1: Select the MatrixWriter application, and key in the first 
element (cell 1-1): 


(>) (MATRIX) 2 


4 
EDIT | VEC =] HD [HID 


Step 2: Enter the first element and the rest of the first row. 


ENTER ) 2 +/-) ENTER ) 0 1:3 | 


EDIT [VEC a] EHI [ib 


Step 3: Use (¥) to end the first row, and enter rest of the matrix. 


1 (ENTER) 0 (ENTER) 3 (ENTER 
3 ¢/-) (ENTER) 5 (ENTER) 1 


EDIT | VEC m| edie | babs 


Step 4: Enter the matrix onto the stack. 


i: [[ 2-28] 
[1 ġ3] 
[ -351 ]] 

MECTRUMATR] LiT | HYP [REAL | EASE | 


While you’re entering a number, the cell coordinate is replaced by the 
command line. When you press to store the value in the cell, 
the cell cursor normally advances to the next cell. 


When you press (¥) at the end of the first row, it sets the number 
of columns in the matrix and moves the cursor to the beginning of 
the next row. You don’t have to press (¥) again—the cell cursor 
automatically wraps to each new row. 
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If the displayed number is wider than the cell width, an ellipsis 
indicates “more to the right” (as in 1.2..). The default cell width is 
four characters. 


Note the two uses of (ENTER): While you’re using the command line 
for data entry, enters data into a cell. When a cell coordinate 
is displayed, enters the entire matrix onto the stack. 


To enter a vector using the MatrixWriter application: 


1. Press (->)(MATRIX) to display the MatrixWriter screen and menu. 

2. Key in the numbers in the vector, and press after each. 

3. After you’ve entered all the numbers in the vector, press to 
put the vector on the stack. 


Vectors normally use only one row of data, so you don’t need to press 
To enter numbers into more than one cell at a time: 


1. Enter the series of numbers into the command line, pressing 
between each number. 


2. Press (ENTER) to enter the numbers. 


To compute elements in the command line as you enter them: 


1. Enter arguments and press command keys as required to execute 
the computation (press to separate arguments). 

2. Press to finish the computation and enter the result into 
the current cell. 


Example: Enter 2.24 in a cell. 


2.2 (SPC) 4 Q7) (ENTER) 1-1 Eoo 


EDIT [VEC a] +HI0 [HID [03 a] G04] 
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Editing Arrays 


Matrix Writer provides functions that make it simple to edit the arrays 
you've entered. 


To edit an array you’re viewing with the MatrixWriter application: 


1. Press (4) œ) (A) (¥) to move the cell cursor. (Use with (@) to move 
the cursor to the far end.) 
2. Use the MatrixWriter operations listed below to add or edit cells. 


. Press (ENTER) to save the changes (or press (CANCEL) to discard 


them) and return to the stack. 


w 


MatrixWriter Operations 


To edit the contents of a cell: 


1. Move the cursor to the cell to be edited. 

2. Press EDIT. 

3. Optional: Press ()(EDIT) to use the regular EDIT menu (see page 
2-12). Press (¢>)(MATRIX) to restore the MatrixWriter menu. 

4. Make the desired changes and press to save them (or 
to discard them). 


To make the displayed cells narrower or wider: 


m Press #4 1& to make the cells narrower and display one additional 
column. 
m Press iT i to make the cells wider and display one less column. 


To control how the cursor advances after an entry: 


m To make the cursor move to the next column after entry, press 
G04 so that the # is visible. 
m To make the cursor move to the next row after entry, press 
so that the # is visible. 
m To keep the cursor from advancing at all after entry, press 
and Gla until neither shows a æ. 
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To insert a column: 


1. Move the cursor to the column where you want the new column 
inserted. 
2. Press +O. A column of zeros is inserted. 


Example: Change the matrix in the first example of this chapter 


2 —2 0 2 —2 4 0 
from 1 0 3 to 1 0 1 3.1 
—3 5 1 -3 S oe, <b 


Step 1: Ifthe matrix is on the stack, bring it into level 1—otherwise, 
enter the matrix into level 1. Then view the matrix in the 
MatrixWriter environment. (This example assumes ixw 
is active.) 


(F) (or enter the matrix) 


EDIT | VEC [eID [Hii 


Step 2: Edit element 2-3: 


VIGI 
EDIT -1 (ENTER) 


ELIT | VEC [SHG [HIN 


Step 3: Insert a new column in front of column 3, and move the cell 
cursor to the top of the new column. 


OO an + 


[+EDk | -RDH | COL | coL [STE [ESTE 
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Step 4: Set top-to-bottom entry mode. Fill in the new column. 


(NXT) i 3-4 E E 
: i=s. 
-4 z 


4 (SPC) 1 (SPC) 3 (ENTER) i 6 
-3 a 3 1 
z] 
[EMT {VEC [Hb [Hits] Gos [ons a] 


Step 5: Restore left-to-right entry mode, then enter the edited 
matrix. 


To delete a column: 


1. Move the cursor to the column you want to delete. 
2. Press SeT. 


To add a column to the right of the last column: 


1. Move the cursor to the right of the last column. 
2, Enter a value. The rest of the column fills with zeros. 


To insert a row: 


1. Move the cursor to the row where you want the new row inserted. 
2. Press . A row of zeros is inserted. 


To delete a row: 


1. Move the cursor to the row you want to delete. 
2. Press 


To add a row below the bottom row: 


1. Move the cursor below the bottom row. 
2. Enter a value. The rest of the row fills with zeros. 
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Summary of MatrixWriter Operations 


Description 


RIE 
RCE 
EEE 


ier ee Oi 


() WATRE) 


Places contents of the current cell in the data entry 
line for editing. (Press ()(EDIT) to get the EDIT 
menu.) Press to save the changes, or 
to discard them. 

For one-row arrays, toggles between vector entry and 
matrix entry. If this key is “on” (‘YEE ), one-row 
arrays are entered into the command line as vectors 
(example: £ i # 2 1); if it’s “off (EUC), one-row 


Narrows all cells so that one more column appears. 
Widens all cells so that one fewer column appears. 
Sets left-to-right entry mode. The cell cursor moves to 
the next column after data entry. 

Sets top-to-bottom entry mode. The cell cursor moves 
to the next row after data entry. 

Inserts a row of zeros at the current cursor position. 
Deletes the current row. 

Inserts a column of zeros at the current cursor position. 
Deletes the current column. 

Copies the current cell to level 1 of the stack. 
Activates the Interactive Stack, which can copy (echo) 
stack objects to the command line. 

Restores the MatrixWriter menu if another menu is 
displayed. 
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Graphic Objects 


Graphic objects (or grobs) encode the data for HP 48 “pictures,” 
including plots of mathematical data, custom graphical images, and 
representations of the stack display itself. The HP 48 provides a 
PICTURE environment for viewing and editing graphic objects. 


Like all objects on the HP 48, graphic objects can be put on the stack 

and stored in variables. On the stack, a grob is displayed as 
Graphic n*m 

where n and m are the width and height in pirels. (A pixel is one 

picture element, or “dot,” in the display.) 


The HP 48 uses two kinds of graphic objects: 


m Plots. These are graphical representations of functions, equations, 
and sets of data that are automatically generated by the PLOT 
application. The HP 48 can zoom plots in any of 15 ways, and can 
numerically analyze function plots. 


m Pictures. These are free-form grobs created “pixel-by-pixel” —either 
automatically using “snapshot” commands, or manually using the 
Picture Editor. 
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To enter the PICTURE environment directly: 
a From the stack, press (;)(PICTURE). 


The Default PICTURE Display 


To exit the PICTURE environment: 


m Press (CANCEL). Note that this does not discard the displayed 
graphics object, but just returns the display to what you were 
viewing before entering the PICTURE environment. 


The Picture Editor allows you to create and modify graphics using 
defined elements (lines, boxes, and circles) or pixel by pixel at a time. 
It also enables you to copy or delete some or all of a picture, and to 
superimpose one picture onto another. 


To begin the Picture Editor: 
a From the stack, press ()(PICTURE) EDIT . 


To return to the main PICTURE environment from the Editor: 


m Press TCT in the third page of the Picture Editor, or press 


(@) END). 
To return to the stack from the Picture Editor: 


m Press (CANCEL). 
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Turning Pixels On and Off 


Two operations, EOT and [t:T-_, allow you to selectively turn 
pixels on and off. If one of these keys is active, it displays a “bullet” 
(#) in its label. 


a If there is a m in the {47+ label, pixels under the cursor are 
turned on. 
m If there is a = in the &7T— label, pixels under the cursor are 


turned off. 


Adding Elements Using the Graphics Environment 


The Picture Editor allows you to add three geometric elements—line 


Each of these elements requires two cursor positions. This means that 
you must tell the Editor to remember the first cursor position while 
you move to the second. You do this by marking the first position. 


To mark the current cursor position: 


a Press ‘MARE from the second page of the Picture Editor menu 
or (x). Press MARE or (x) again to remove the mark. Also, any 
operation that requires a mark will create a mark when you first 
press its key, and then execute the operation when you press its key 
a second time. 


To draw a line segment on the current grob: 


1. From within the Picture Editor, move the cursor to where you want 
one endpoint of phe ese ements 
2. Press (x) (or HARE i 


3. Move the cursor to the otlier EN and press “LEHES. 


To draw a box on the current grob: 


1. From within the Picture Editor, move the cursor to where you want 
one corner of the box. 
2. Press (x) (or NARE or BOX ). 
3. Move thig cursor to the opposite corner of the desired box and press 
Bo 
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To draw a circle on the current grob: 


1. From within the Picture Editor, move the cursor to where you want 
the center of the circle. 


2. Press (x) (or or CTREL). 


3. Move the cursor to: any point on the perimeter of the desired circle 
and press © 


To toggle a line segment on the current grob: 


1. From within the Picture Editor, move the cursor to one endpoint of 
the segment. 

2. Press (x) (or z 

3. Move the cursor to the other snd vaut and press fi . All pixels 
between the mark and the cursor are toggled—those that were on 
are now off, and vice versa. 


Editing and Erasing a Picture 


To erase an entire picture: 


a While viewing the picture press ERASE (or ()(CLEAR) asa 
shortcut). 


To erase a rectangular area of the picture: 


1. Move the cursor to one corner of the rectangular area to be erased, 
and press (x) (or GEL ) to mark it. 
2. Move the cursor to the opposite corner of the rectangular area. 


3. Press (NXT) (or as a shortcut). 


To copy a rectangular area of the picture to the stack: 


1. Move the cursor to one corner of the rectangular area you want. to 
copy, and press (x) (or i) to mark it. 
2. Move the cursor to the opposite corner of the region. 


3. Press . The area is copied to level 1, and the 


picture remains in the display. 


To superimpose a second grob on top of the current one: 


1. Put the second grob on stack level 1. 
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2. Open the Picture Editor (|) (PICTURE T) and move the 
cursor to the upper left corner of the rectangular region where you 
want to superimpose the grob. 


3. Press (NXT) (NXT) 
To copy the entire picture (the contents of PICT) to the stack: 


m While viewing the picture, press (or -). A copy of 
PICT is entered on level 1, and the picture remains in the display. 


Example: Create and edit a small picture. This will illustrate some 
of the Picture Editor operations discussed above. 


Step 1: Begin the Picture Editor and erase PICT. Then use 
to draw a horizontal line from the center halfway to the left 
edge. 


DET 
GOCE 


a (hold down) 


LINE [TLINE 


Step 2: Turn off line-drawing, then use L. THE to draw a vertical line 
from the current cursor position halfway to the top edge. 


ay (to mag 


(A) (hold down) Í 


pos 


LINE [TLINE| Eln [CIRCE] 


Step 3: Move the cursor to the lower end of the line, and toggle the 
line off. 


(¥) (hold down) 


LINE [TLINE] EDH [CIRCL| 
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Step 4: Draw a circle using the existing mark and the current cursor 


position. 
cs 


LINE [TLINE| ED% [CIKEL] 


Step Delete the lower semicircle. 


(move to left of circle) 

(A) (move halfway up the circle) E 
(to mark) = 
move below the circle) 


Mm 
Œ) (move right of the circle) 
DEL 


LINE |TLINE] BOX [CIRCL] 


Saving and Viewing Graphic Objects 


The PICTURE environment displays and uses one grob at a time. 
The current grob is always stored in the reserved variable PICT. 
Think of PICT as the HP 48’s built-in “chalkboard,” where functions 
are plotted and pictures are drawn. Grobs (plots and pictures) can 
be stored using any valid name of your choice, but to be viewed the 
evaluated name must be copied into PICT. 


To save the currently displayed grob: 


1. While viewing the grob in the PICTURE environment, press (STO). 
This copies the grob to stack level 1. 

2. Press one or more times to exit the PICTURE 
environment and return to the stack. 

3. Using ‘ delimiters, type in a name. 

4. Press (STO). The grob is stored in the current directory. 
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To view a grob that is not currently displayed: 


Save the currently displayed grob (see above) if you want to keep it. 
Recall the desired grob (do not use ‘ delimiters) to level 1. 

Type FILT into the command line (do not use ' delimiters). 

Press (STO). 

Press (€,)(PICTURE). 
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Graphic Object Coordinates 


Pixels in a grob can be specified with either pizel coordinates or 
user-unit coordinates. 


User-unit coordinates Pixel coordinates 
(-6.5, 3.2) (6.5,3.2)  {#0, #0} {#130, #0} 
(-6.5, -3.1) (6.5, -3.1)  {#0, #63} {#130, #63} 


User-Unit Coordinates vs. Pixel Coordinates 


Pixel coordinates (the default) i in a standard size PICT grob are 
numbered from < #4 #8 3 in the upper-left corner to 1 #158 #62 3 
in the lower-right corner. Notice that pixel coordinates are given as a 
list containing two binary integers—the first designating the column 
and the second designating the row. Pixel coordinates are the most 
convenient to use when manipulating pictures. 


User-unit coordinates depend on the current settings in PPAR (see 
chapter 22) but their default values range from ¢-6.5, 3.27 in the 
upper-left corner to £6.5; ~. 13 in the lower-right corner. User-unit 
coordinates are given as a complex number (ordered pair), with the 
real part representing the horizontal coordinate and the imaginary 
part representing the vertical coordinate. User-unit coordinates are 


most convenient for use when plotting. 
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The PRG command menus contain two submenus, GEE 


and PICT 


, that contain programmable commands useful for 


manipulating pictures and picture elements. 


Graphics Object Commands 


Programmable 
Command 


Description 


LIME 


TETHE 


Inge img pia 


BCLS 


PICT 


PDIM 


LINE 


TLINE 


BOX 


ARC 


PIXON 


PIXOFF 


Puts the name FIET on the stack so 
you can access the PICT graphics 
object as if it were stored in a variable. 
Redimensions PICT to the dimensions 
given in levels 2 and 1. Dimensions are 
either the width and height (given in 
pixels) or the minimum and maximum 
coordinates (given in user-units). 
Draws a line in PICT between the 
coordinates in levels 2 and 1. 

Same as LINE except that pixels along 
the line are toggled on or off, rather 
than turned on. 

Draws a box in PICT using two 
coordinate arguments as opposite 
corners. 

Draws an arc in PICT centered at a 
coordinate (in level 4) with a given 
radius (in level 3) counterclockwise from 
6, (in level 2) to @» (in level 1). (The 
coordinate and radius must both use 
user-units or pixels.) 

Turns on the pixel in PICT specified in 
level 1. 

Turns off the pixel in PICT specified in 
level 1. 
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Graphics Object Commands (continued) 


Key Programmable Description 
Command 
PIX? Returns į if the pixel specified by the 
coordinate in level 1 is on, or & if the 
pixel is off. 

p PVIEW Displays PICT with the specified 
coordinate at the upper left corner of 
the graphics display. 

p PX—C Converts a pixel coordinate 
© #nx #ny 3 toa user-unit coordinate 
EL yl. 
C—PX Converts a user-unit coordinate $g, y? 


to a pixel coordinate © #nx #ny +. 


BLANK 


GOR 


GXOR 


(To graphics object.) Converts an 
object (level 2) into a graphics object 
using real number n (0 to 3 from 

level 1) to specify the character size. 
The resultant graphics object is a string 
of small (n=1), medium (n=2), or large 
(n=3) characters. For n=0, the 
character size is the same as for n=3, 
except that for algebraic and unit 
objects, the resulting graphics object is 
the EquationWriter picture. 

Creates a blank graphics object on the 
stack of size #nx (in level 2) by #ny (in 
level 1). 

(Graphics-object OR.) Superimposes 
the level 1 graphics object onto the level 
3 graphics object. The upper left corner 
of the level 1 graphics object is 
positioned at coordinates specified in 
level 2. 

(Graphics-object XOR.) Same as GOR 
except that the level 1 graphics object 
appears normal on a light background 
and inverse on a dark background. 
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Graphics Object Commands (continued) 


Programmable 
Command 


Description 


Lins 


STEE 


RHIN 


SUB 


REPL 


—LCD 


LCD— 


SIZE 


ANIMATE 


(Subset.) Extracts and returns to the 
stack a portion of a graphics object 
(level 3) defined by two coordinates 
(levels 2 and 1) that mark the diagonal 
corners of the rectangle to be extracted. 
(Replace.) Same as GOR except that 
the level 1 graphics object overwrites 
the level 3 graphics object where the 
level 1 graphics object is located. 
(Stack to LCD.) Displays the graphics 
object from level 1 in the stack display, 
with its upper left pixel in the upper left 
corner of the display. It overwrites all of 
the display except the menu labels. 
(LCD to stack.) Returns to level 1 a 
graphics object representing the current 
stack display. 

For the graphics object in level l, 
returns the width (level 2) and height 
(level 1) in pixels. 

Takes from levels 2 through n +1 a 
sequence of grobs and from level 1 
either: a) the number of grobs (n) or b) 
a list containing four items: the number 
of grobs (n), a list containing the pixel 
coordinates (© #nx #ny 3) of the 
upper left corner of region where the 
animation is to be located, the time 
delay (in seconds) between each 

“frame” of the animation, and the 
number of times to repeat the 
animation sequence (0 = repeat 
indefinitely until interrupted by a 
keystroke). It then displays each grob in 
sequence in the specified location for 
the specified number of seconds. 
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Unit Objects 


The Units application contains a catalog of 147 units that you 
can combine with real numbers to create unit objects. The Units 
application lets you do the following: 


a Convert units. For example, you can convert the unit object 1% 
to 3 i i 


m Factor units. For example, you can factor 284 with respect to 1M. 


and return #8 Memes. 


m Calculate with units. For example, you can add 1 ftes to 


Overview of the Units Application 


The Units application consists of two menus: 


m The UNITS Catalog menu ((¢>)(UNITS)), which contains the HP 48 
units organized by subject. This menu enables you to create unit 
objects, and to convert between related units in the catalog. 


m The UNITS Command menu ((4)(UNITS)), which contains 


commands for converting units and for managing unit objects. 


Units and Unit Objects 


The Units application is based on the International System of Units 
(SI). The International System specifies seven base units: m (meter), 
ka (kilogram), = (second), A (ampere),  (kelvins), zg (candela), and 
(mole). The HP 48 makes use of two additional base units: r 
(radian) and sr (steradian). The UNITS Catalog menu contains these 
nine base units, and 141 compound units derived from the base units. 


Pah 
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For example, im (inch) is defined as .0254 į, and Fru (Faraday) is 
defined as 96487 :. (See appendix E for a complete listing of the 
built-in units and their SI values.) 


A unit object has two parts: a number (a real number) and a unit 
expression (a single unit or multiplicative combination of units). The 
two parts are linked by the underscore character _. For example, 
&_im (2 inches) and &, 282_sa1-h (8.303 US gallons per hour) are 
unit objects. Like other object types, a unit object can be placed on 
the stack, stored in a variable, and used in algebraic expressions and 
programs. 


When you perform a unit conversion, the HP 48 replaces the old unit 
expression with a new unit expression you specify, and automatically 
multiplies the number by the appropriate conversion factor. 


Operators in unit objects follow this precedence order: 
1. « > (highest precedence) 
3. #and ~” 


For example, ¥_is°2 is 7 meters per second squared, and 


Taimest” is 7 square meters per second squared. 


The UNITS Catalog Menu 


The UNITS Catalog menu ((@)(UNITS)) displays a three-page menu 
of “subject” keys, each of which, when pressed, displays a submenu 


of related units. For example, (> )(UNITS i 


two-page menu of units for pressure. 


The individual keys in each submenu behave differently than standard 
menu keys, as described throughout this chapter. In Immediate-entry 
mode, you can use the shift keys with the menu keys as follows: 


m An unshifted menu key creates a unit object by combining the real 
number on level 1 with the unit expression that corresponds to 
that key. (In Algebraic- or Program-entry, the unshifted keys act 
as typing aids, echoing the corresponding name into the command 
line.) 
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a A left-shifted menu key converts the unit object in the command 
line or level 1 to the corresponding unit. 


m A right-shifted menu key divides by the corresponding unit. This 
helps you create unit expressions with units in the denominator. 


Creating a Unit Object 


The UNITS Catalog menu provides a simple method for creating a 
unit object. 


To create a unit object on the stack: 


Bee . ; 10 » 
1. Key in the number part of the unit object. / 


2. Press (@)(UNITS) and select the appropriate subject menu. 

3. Press the menu key for the unit you want. (If you want the inverse 
of the unit, press (f>) and the menu key.) 

4. For compound units, repeat steps 2 and 3 for each individual unit 
in the unit expression. 


When you press a menu key in the UNITS Catalog menu, the HP 48 
first enters a corresponding unit object on the stack with the number 
value 1. Then, for an unshifted key, it executes = (multiply), or, for a 
right-shifted key, it executes ~ (divide). 


To create a unit object in the command line: 


1. Key in the number. 
2. Key in the _ character (press (@)(_)). This activates 
Algebraic-entry mode. 
3. Key in the unit expression as you would an algebraic expression: 
a To key in a unit name, either press the corresponding menu key 
or spell the unit name. 


a To create compound units, press (x), ©), Q7), and (D) as 


required. 


Note that unit names are case-sensitive. For example, Hz (hertz) 
must be typed with uppercase H and lowercase =. (For legibility, 
all letters in menu keys are uppercase. Don’t confuse the menu-key 
representation of a unit with its proper name.) 
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By spelling unit names, you can create a unit object without switching 
between submenus in the UNITS Catalog menu. However, the menu 
keys eliminate errors resulting from incorrect spelling and incorrect use 
of uppercase or lowercase. 


ate 


Example: Create the unit object &_Bhuetfi~ 
command line. 


FE in the 


Step 1: Key in the number and the _ character. Then key in the 
unit expression using alpha characters and enter the unit 
object. 


8 œQ l: B_Btue (Ft 2ehe"F ) 
QQB\YTQUOAH\O) SRihniew ia trata 
QF aT @C? 

WOHIWD@AE)6@F 


To create a unit object using the EquationWriter application: 


L. Press (€) (EQUATION). 
2. Enter the number, press (¢>)(-), and enter the unit expression using 
standard Equation Writer notation. 


3. Press (ENTER). 


The EquationWriter application lets you build algebraics that contain 
unit objects, showing you the unit expression as you would write it on 
paper. Inverse units are displayed in fractional form, and exponents 
are displayed as superscripts. 


Unit Prefixes 


You can also insert a unit prefix in front of a unit to indicate a power 
of ten. The following table lists the available prefixes. (To key in x, 


press (a) (>) N.) 
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Unit Prefixes 


Prefix Name | Exponent Prefix Name | Exponent 
y yotta +24 d deci —1 
2 zetta +21 c cent —2 
E exa +18 m milli —3 
F peta +15 u micro —6 
i tera +12 ri nano —9 
giga +9 E pico —12 
i mega +6 f femto —15 
k or kilo +3 a atto —18 
hoor H hecto +2 z zepto —21 
(K deka +1 td yocto —24 


Most prefixes used by the HP 48 correspond with standard SI 
notation, with one exception: “deka” is “D” in HP 48 notation and 
“da” in SI notation. 


Note You cannot use a prefix with a built-in unit if the 
resulting unit matches another built-in unit. For 

g example, you cannot use mir to indicate milli-inches, 
because mir is a built-in unit indicating “minutes.” 
Other combinations that match built-in units are F's, 
da, gd, ph, flanm, mmi, meh, keh, ch, et, FL, au, 
Tu, wel, ue. 


The HP 48 provides several ways to convert unit objects to different 
units: 


m The UNITS Catalog menu—converts to built-in units only. 
ma The CONVERT command—converts to any units. 
m The UBASE (base units) command—converts to SI base units only. 


If you’re working with temperature units, see “Working with 
‘Temperature Units” on page 10-10. 
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Using the UNITS Catalog Menu 

The UNITS Catalog menu lets you convert the unit object in stack 
level 1 to any dimensionally consistent unit in the menu. 

To convert units to a built-in unit: 


1. Enter the unit object with the original units. 

2. Press (>)(UNITS) and select the subject menu that contains the 
desired unit. 

3. Press (+) and the menu key for the desired unit. 


Using CONVERT 


You can use the CONVERT command to convert unit objects between 


any dimensionally consistent unit expressions. 


To convert to any units: 


1. Enter the unit object with the original units. 
2. Enter any number (such as 1) and attach the units you want to 
convert to. 


3. Press (4)(UNITS) CORNY. 


CONVERT converts the level 2 unit object using the units from the 
level 1 object. It ignores the number part of the level 1 unit object. 


Using UBASE (for SI Base Units) 


The UBASE command converts a compound unit into its equivalent 
SI base units. 


To convert units to SI base units: 


1. Enter the unit object with the original units. 


2. Press ()(UNITS) JERSE. 
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Converting Angular Units 


Planar and solid angles are associated with actual units. However, 
although this distinguishes them from scalars (dimensionless 
numbers), the HP 48 allows you to convert between units of angle 
and scalars. The conversion will interpret the scalar according to the 
current angle mode setting (degrees, radians, or grads). 


Unit Symbol Definition | Value 
Arcmin arcmin /21600 unit circle | 290888208666 x 104 r 
Arcsec z 1 /i296000 unit circle | 4.8481368111 x 10° r 
Degree 5 /360 unit circle 1.74532925199 x 10? r 
Grad i /4o0 unit circle 1.57079632679 x 10? r 
Radian i /ox unit circle lr 
Steradian | sr /an unit sphere 1 sr | 


Calculating with Units 


The HP 48 lets you execute many arithmetic operations with unit 
objects, just as you would with real numbers: 


Addition and subtraction (dimensionally consistent units only) 
Multiplication and division 

Inversion 

Raising to a power 

Percentage calculations (dimensionally consistent units only) 
Comparisons of values (dimensionally consistent units only) 
Trigonometric operations (planar angular units only) 


Several additional math operations are available, but work only on the 
number part of the unit object. 
To calculate with unit objects: 


1. Enter the unit objects. 
2. Execute the commands. 


Units are automatically converted and combined during the 
calculation, though certain operations require dimensionally consistent 
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units. Such operations convert results with units to the units from the 
object in level 1. 


Temperature units require special note: see “Working with 
‘Temperature Units” on page 10-10. 


The trigonometric operations SIN, COS, and TAN, operate only on 
unit objects with planar angular units: radians (1), degrees (*), grads 
(arad), arc-minutes (arcmin), or arc-seconds (acs). The result is a 
dimensionless real number. 


Example: Subtraction. Subtract 23_in from 4 


(@)CONITS) LENS i) 9_in 
10 1 ET [m | cnda vn | FT [IN] 


O 


Example: Unit Multiplication and Division. Multiply 3&_¢+ by 
45 #4, then divide by 3.2 (days). 


Step 1: First, multiply the two unit objects. 


(UNITS) LENG 1: zeo ftne 
ce F T m [ocra [ret] vo T FT | IN | 
45 eT 


3) 


Step 2: Enter the third unit object and divide. 


TIME l: r93. 125_ft^żzd 
ŒC T E oe oe l n fn] e one 
G) 


Example: Powers. Raise 2_f%.°s to the sixth power. Find the 


square root of the result. Then find the cube root of that 
result. 


Step 1: Enter the unit object and raise the unit object to the sixth 
power. 


2 (UNITS) SPEED FITS 
66D 


1: bt_ft"6s"6 
Pris [ons ets EPH [MPH [KENDT] 
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Step 2: Now find the square root of the result. 


1: afi ss" 3 
Pris [eM ets | EPH [MPH [KNOT] 


Step 3: Find the cube root of the result. 


3 c3 : 
Ow eee AER 


Example: Percentage. 4.2. i is what percent of Lim 3 


Wie: 1 SEM 1: cap 6293723190 


MTH 


Factoring Unit Expressions 


The UFACT command factors one unit within a unit expression, 
returning a unit object whose unit expression consists of the factored 
unit and the remaining SI base units. 


To factor units within a unit expression: 


1. Enter the unit object with the original units. 
2. Enter any number (such as 1) and attach the units you want to 
factor out. 


3. Press (>) (UNITS) LIF RCT. 


UFACT factors the units of the level 1 object from the level 2 unit 
object. 


Using Unit Objects in Algebraics 


Unit objects are allowed in algebraics—you enter them just as you 

enter them in the command line. In addition, the command line 

poe e numbers instead of real numbers, converting 
oft, for example, to +1 ft when entered on the stack. 


+ and ~ are allowed in the number. However, the _ character: takes 
precedence over + and ~. Thus | £4452 AL returns 3_f4, but 
hae Ft EVAL returns + Errori Drmcoms ii Uribe. 
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The HP 48 lets you work with temperature units the same ways you 
work with other units—ezcept you must recognize and anticipate the 
difference between temperature level and temperature difference. 
For example, a temperature level of 0 °C means “freezing,” but a 
temperature difference of 0 °C means “no change.” 


When °C or °F represents a temperature level, then the temperature 
is a unit with an additive constant: 0 °C = 273.15 K, and 

0 °F = 459.67 °R. But when °C or °F represents a temperature 
difference, then the temperature is a unit with no additive constant: 
1°C =1K, and 1 °F =1°R. 


Converting Temperature Units 


Conversions between the four temperature scales (K, °C, °F, and 
°R) involve additive constants as well as multiplicative factors. The 
additive constants are included in a conversion when the temperature 
units reflect actual temperature levels, and are ignored when the 
temperature units reflect temperature differences: 


m Pure temperature units (levels). If both unit expressions consist of a 
single, unprefixed temperature unit with no exponent, the UNITS 
Catalog menu or CONVERT performs an absolute temperature 
scale conversion, which includes the additive constants. 


a Combined temperature units (differences). If either unit expression 
includes a prefix, an exponent, or any unit other than a temperature 
unit, CONVERT performs a relative temperature unit conversion, 
which ignores the additive constants. 


Example: Convert 25_" to "F 
(@)GNTS) XT) 1: 77_°F 
25 "E D CS ae o 
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Example: Convert : 


Step 1: First, create the unit object 2S_"f-min. 
(>) (UNITS) (NXT) -F 
25 EE 
M) 1 


Step 2: Enter a unit object containing the new units. 


(MEN 1 TF - en 
(MENU) i ` — Femin 

Step 3: Perform the conversion. 
(D Nts) i 1: 45_"Femin 


PONY UEASE] OVAL (UFACTISUNIT | 


Calculating with Temperature Units 


Temperature units are automatically converted and combined during 
calculations. 


m Pure temperature units (levels or differences). The relational 
operators (<, >, <, >, ==, #) interpret pure temperatures as 
temperature levels relative to absolute zero for all temperature 
scales. Before making the calculation, the HP 48 converts any 
Celsius or Fahrenheit temperature to absolute temperatures. 


The operators + and — and the functions ®%CH and %T require 
that pure temperature arguments either both be absolute 
temperatures (K or °R), both °C, or both °F. This ensures that 
such operations retain their correct algebraic properties. 


For all other functions, pure temperature units are interpreted 
as temperature differences—they re not converted before the 
calculation. 


ws Combined temperature units (differences). Temperature units with 
prefixes, exponents, or other units are interpreted as temperature 
differences—they’re not converted before the calculation. 
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Example: Determine if 12 °C is greater than 52 °F. (The > operator 
interprets temperatures as levels.) 


oe) (NXT) T 3 1: 1 
ca aa ENEN 


The result shows the test is true (12 °C is greater than 52 °F). 


Example: Calculate the final temperature for an increase of 18 °F 
from the current temperature of 74 °F. 


(JUNTS) NXT) TENF 1: 92_"F 
18 eE H4 e eee TO 


Example: For a coefficient of linear expansion a of 20 x 107° 1/°C 
and a temperature change AT of 44 °C, calculate the 
fractional change of length given by a AT. (The x 
command interprets temperatures as differences.) 


(>) UNITS) (NXT) TENE l: Malala 
20 60 E eee 


44E &) 


Whenever you must use absolute temperatures in a compound unit or 
expression, be sure to enter the temperatures using absolute scale. 
The HP 48 will not convert from °C or °F to the absolute scale 
correctly once the temperature has become a part of a combined 
expression. 


Example: The ideal gas equation of state is PV = nRT, where P 
is the pressure exerted by the gas (in atmospheres), V 
is the volume of the gas (in liters), n is the amount of 
the gas (in moles), R is the ideal gas constant (0.082057 
liter-atmospheres/kelvin-mole), and T is the temperature 
of the gas (in kelvins). 


Assuming ideal gas behavior, calculate the pressure 
exerted by 0.305 mole of oxygen in a volume of 0.950 liter 
at 150 °C. 
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Step 1: First, enter the temperature. 


(UNITS) 1: 156_*C 
a p eee e 
150 "E 


Step 2: Convert the units to kelvins. This conversion works correctly 
at this point because the temperature is still “pure,” and not 
yet part of a compound unit. 


CR 1: 423. lok k 
aS ae ae a a 


Step 3: Multiply T (already in level i by n (0.305 mole). 


_(@) GATS) nass 129. aioe Kamol 
305 MOL u ieoi oe 
&) 


Step 4: Multiply nT by R, the ideal gas constant. Retrieve R from 
the Constants Library before multiplying. 


DEALE) COLIB Q@R 1: al la aati 
ee) (0 1 TT 


Step 5: Divide by V (0.950 liter) to calculate P. 


95 (NTS) VOL (XT 1: o: ik iba 
| “ ¥ 
o 
Step 6: Convert the pressure units to atmospheres. 
(NXT) FRESS : i 7 
a NXT i -l liroartozr atm 


Step 7: Convert the pressure (in atmospheres) to SI base units. 


(4) (UNITS) VERASE l: 1 L EZror-kg-ím 
#5 


PONY [VERE] UAL [UFACTJ#UNIT] | 
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Creating User-Defined Units 


If you use a unit that’s not contained in the UNITS Catalog menu, 
you can create a user-defined unit that behaves just like a built-in 

unit. (The Equation Library contains four user-defined units—see 

page 25-15.) 


To create a user-defined unit: 


1. Enter a unit object using built-in or previously defined units that 
equals value of 1 new unit. 

2. Store the unit object in a variable—the variable name is used as 
the name of the new unit. 

3. Optional: Add a unit object having the user-defined unit to the 
CST menu—see below. The number part is ignored. (Custom 
menus are described on page 30-1.) 


You can’t use the unit key in the VAR menu like unit keys in the 
UNITS menus—because VAR menu keys store and recall objects. 
However, if you add the user-defined unit to the CST menu, you can 
use the CST menu key to enter and convert your user-defined units— 
just like UNITS menu keys. 


Example: Use the built-in unit 4 (day) to create the user-defined unit 
HEEK. To do this, store the unit object ¥_d in variable WEEK. Enter 
a list containing an object with the new units: £1 _HEEK >. Store the 
list in the custom menu and display the menu—press (4)(MODES) 


MEHL MEME. 


Additional Commands for Unit Objects 


Key Programmable Description 
| Command 


(ce) UNITS) 


LAL UVAL Returns the number part of the level 1 
unit object to level 1. 

SUN DT —UNIT Combines a number from level 2 with a 
unit object from level 1, ignoring the 
number part of the level 1 object, to 
form a unit object in level 1. 
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Using Mathematical Functions 


Built-In Functions and Commands 


Built-in functions and built-in commands are subsets of HP 48 
operations. An operation is any action the calculator can perform. 
(Every time you press a key, you execute an operation.) But not all 
operations are equivalent to one another. They are classified into the 
following categories: 


m Operation. Any built-in action represented by a name or key. 
m Command. Any programmable operation. 
m Function. Any command that can be included in algebraic objects. 


a Analytic function. Any function for which the HP 48 provides an 
inverse and derivative. 


Analytic functions are a subset of functions—functions are a subset of 
commands—-and commands are a subset of operations. 


SIN, for example, is an analytic function—it has an inverse 

and derivative, can be included in an algebraic object, and is 
programmable. SWAP (the command to swap stack levels 1 and 2), 
however, is a command—it can be included in a program, but it can’t 
go in an algebraic and has no derivative or inverse. 


The operation index in appendix G tells you how each operation is 
classified. Also, throughout the manual, HP 48 activities are referred 
to as operations, commands, functions, or analytic functions where 
appropriate. 


Built-in function and built-in command objects describe the HP 48 
command set. You can think of them as built-in program objects. 
(Operations that aren’t commands are not objects—you can’t include 
them in programs.) 
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Expressing Functions: Algebraic Syntax 


The difference between functions and other commands is that 
functions can be included in algebraic expressions. The syntax used 
by a function determines how it interprets its inputs (or arguments). 
Functions can be classified into three types based on their syntax: 


@ Prefix functions. Functions such as ‘SIH¢#2!' and 'HARCHa yo? 
whose name (or operator) comes before its argument(s) (which are 
listed in parentheses and separated by commas). 

m Infix functions. Functions such as + and = that come between their 
two arguments. 

m Postfix functions. Functions such as ! (factorial) that come after 
their argument. 


, Ñ is treated as a prefix 


Note In the expression 'ACBst2! 
i function and not as a multiplicative argument. The 
L] HP 48 interprets the expression as “apply function 
Fito the product of È and ©,” instead of “multiply 


A by the product of E and ©.” If multiplication is 
intended, be sure to include the multiplication 
operator, + (or * in the EquationWriter). 
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Algebraic objects use algebraic syntax and thus use the normal rules 
of algebraic precedence to determine the order in which the functions 
are executed. Functions with higher precedence are performed first, 
and functions with the same precedence are performed from left to 
right. The HP 48’s functions have the following algebraic precedence, 
from highest (1) to lowest (11): 


1. Expressions within parentheses. Expressions within nested 
parentheses are evaluated from inner to outer. 
Prefix functions (such as SIN, INV, or LOG). 
Postfix functions (such as £). 

Power (*). 

Negation (~), multiplication (#), and division (7). 
Addition (+) and subtraction (~). 

Comparison operators (==, +, £, >, £, or 3). 

8. Logical operators AND and NOT. 

9. Logical operators OR and XOR. 

10. The left argument for | (where). 

11. Equals (=). 


NO oR wy 


Example: 
AC S+E | Cubes A, then adds B to that quantity, since * has a 
higher precedence than +. 
TA OEE Sf Raises A to the power 3+8, since an expression 


within parentheses has a higher precedence than * 


Expressing Functions: Stack Syntax 


Although there are very few postfix algebraic functions, all functions 
on the HP 48 can be executed in postfix form using the stack. Stack 
syntax is postfix syntax, where the arguments are entered first, 
followed by the command or function name. Postfix syntax is often 
a more efficient means of using a series of functions than is standard 
algebriac syntax. 


Thus the HP 48 allows you to use functions in two distinct ways: 
algebraic syntax within algebraic objects or in postfix syntax executed 
directly on Mats stack. For example, the sine function can be used 
either as '2IH€#3' or '#' SIM and addition can be either '#+'"' or 


Pad ba p 
{ $ 
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Remember: Unless you surround functions in single-quotes (the ' ' 
tick-mark delimiters), the HP 48 assumes that you are using postfix 
syntax whenever you invoke the name of a function and thus uses 
(or attempts to use) objects from the stack as the arguments for the 
function. 


Expressions and Equations 


An ezpression is an algebraic that does not contain an = function. 


When you use an equation as the argument of a function, the function 
is applied to both sides, and the result is also an equation. For 
example, ‘#="' SIM returns ‘SINGM3=SIHMey 2! . 

In the HP 48, = generally means equating two expressions. The 
DEFINE command (()(DEF)) interprets = differently—it stores the 
expression on the right side of the equal sign in the name on the left 
side (see 11-7 for more details). 


Symbolic Constants 


The HP 48 has five built-in constants that can be included in algebraic 
expressions either as symbolic constants or as 12-digit numerical 
approximations. The five constants are these: 


aon (2.141392365359), the ratio of a circle’s perimeter to its 
diameter. 


122946), the natural logarithm base. 
, the square root of (-1). 


representable by the HP 48. 
m MINR (1.E-43%), the smallest positive real number representable 
by the HP 48. 


The five constants are available in both symbolic and numeric forms 
in the MTH CONSTANTS menu, accessed by pressing 

OMS . Three of the constants can also be entered directly from the 
main keyboard: 
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a Press (4)(w) to obtain 7. 
m Press (@)(4) E to obtain e. 


a Press (@)(4) I to obtain 2. 


The HP 48 also provides 40 physical constants (with their units) 
through its Constants Library. The CONST function allows these 
constants to be used in symbolic form. See page 25-14 for details. 


Controlling How Symbolic Constants are Evaluated 


System flags —2 (Symbolic Constants) and —3 (Symbolic Results) 
control whether evaluating symbolic constants return symbolic or 
numeric results. The default setting for both flags is clear. LE 


To control the evaluation of symbolic constants: 


m To leave a symbolic constant unchanged during evaluation, clear 
flags —3 and —2 (their default states). 

m To replace a symbolic constant with its numeric value during 
evaluation, set flag —3. 

a To replace a symbolic constant with its numeric value except 
when it’s the argument of a function, clear flag —3 and set flag 
—2. Pressing causes the numeric value to be used, but the 
execution of another function (/, SIN, LOG, and so forth) does not. 

a To force all constants to evaluate numerically regardless of the flag 


settings, press ()(NuUM). 


Using Built-in Math Functions 


The next six chapters (chapters 12-17) are devoted to the built-in 
math functions available on the HP 48. The functions are grouped 
into chapters and divided into sections. 


Most of the common arithmetic and scientific functions are located on 
the main keyboard. But there are many, many more that are located 
in the submenus accessed using the (MTH) key. The following table 
describes how to find each group of functions on the HP 48 and where 
in the manual it is discussed. 
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Finding Mathematical Functions on the HP 48 


Bm 
oO 
< 
> 
[e] 
w 
5 
Q 


Trigonometric Functions 


Hyperbolic Functions (MTH) HYF 
Probability Functions FREDE 
Percentages REAL 
Built-In Constants NXT) COMES 


mm 
© 
ae Lun 
® 
ci 
i 
be 
CET 


Real-Number Functions 
Complex Functions 
Vector Functions 
Fourier Transforms 


DTE 


mi 


=i i 
ITITI 
Z 
x 
+ 
3 
T 
Mm 


= 
x 
4 
4 
TY 
Fa. 


Date and Time Arithmetic 
Fraction Arithmetic 


al 
= 
m 


(a) GvmBotic) 


Lists 
Sequences and Series (MTH) LIST 


Recursive List Procedures (PRG) LIST 


Matrix Functions MTH) MATE 
Linear Algebra MATE 
Number Base Conversions (MTH) BASE 
Binary Arithmetic BASE 
Boolean Logic Operations BASE LOGIC 


Applying Functions to MTH) LIST. Keyboard 


Topic or Group Access Reference 
Arithmetic Keyboard Chapter 12 
Exponential Functions Keyboard Chapter 12 
Logarithmic Functions Keyboard Chapter 12 


Chapter 12 
Chapter 12 
Chapter 12 
Chapter 12 
Chapter 12 
Chapter 25 
Chapter 12 
Chapter 12 
Chapter 13 
Chapter 13 
Chapter 14 
Chapter 14 
Chapter 15 
Chapter 15 
Chapter 15 
Chapter 16 
Chapter 16 
Chapter 17 


Chapter 17 
Chapter 17 


User-Defined Functions 


You can add your own user-defined functions. A user-defined function 


behaves like a built-in function is several ways: 


a It takes its arguments from the stack or in algebraic syntax. 


m It takes symbolic arguments. 
a It can be differentiated. 


11-6 Using Mathematical Functions 


Creating a User-Defined Function 


The DEFINE command lets you create a user-defined function 
directly from an equation. The equation must have the form 
‘name * arguments = EEPPEssion `. 


To create a user-defined function: 


1. Enter an equation that specifies the function name and its 
arguments on the left side, and the expression that defines the 
calculation on the right side. On the left side, use commas to 


separate multiple arguments. 
2. Press (EF) (the DEFINE command). 


Example: Use DEFINE to create CMB, a user-defined function that 
calculates the number of combinations C of n different 
items taken 1, 2, 3,... n at a time: C= 2” — 1. 


Step 1: Enter the equation for CMB. 


ooa M AO) 


Qw 
MRB DONO! 
Step 2: Execute DEFINE. Select the VAR menu and note that it 
now contains the user-defined function CMB. 
(DEE) (cre | PPAR] A [PRTPALIOPARL EXAM 


1: 'CMBCn=2*n— 1! 
VECTRPMATR| List | Wve [REAL | EASE | 


Executing a User-Defined Function 


A user-defined function is executed just like a built-in function—it 
can take numeric or symbolic arguments, either from the stack or in 
algebraic syntax. 
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To execute a user-defined function: 


m To use the stack, put the arguments on the stack in the same order 
they appear in the left side of the function definition (the last 
argument should be in stack level 1), then press the function key in 
the VAR menu (or type the function name and press (ENTER)). 

m To use algebraic syntax, press C), press the function key in the 
VAR menu (or type the function name), press (€)(()), enter the 
algebraic arguments in their proper order and separated by commas, 


then press (or press to evaluate the expression). 


Example: Execute the user-defined function CMB from the earlier 
example to make the following calculations. 


Step 1: Calculate the total number of ways to combine one or more 


of four items (n = 4). 


4 CHE 1: 15 
Lee | PPAR] A [PRTPALIOPAR|ESAM| 


Ste 2: For the same value of n, calculate the combinations in 
P 
algebraic syntax. 


Q CE QO 4 
ED 


Step 3: Calculate CMB(Z) in algebraic syntax, where Z is a formal 
variable. (Purge Z to make sure is doesn’t contain an 


object.) 
Z (PURG) R re ie i 


Nesting User-Defined Functions 


Just like built-in functions, user-defined functions can be included in 
the defining expression of a user-defined function. 
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Example: Write a user-defined function to calculate the ratio of 
surface area to volume of a box. The formula for this 
calculation is 


A Ahw+hl+ wl) 
Vvo hwl 

where h, w, and l are the height, width, and length of the 

box. 


Step 1: First, create a user-defined function BOXS to calculate the 
surface area of the box. Use the EquationWriter application 
to key in the equation. 


DENTAN) 
©) @) BOXS QO |) E 
SPC) (4) W GPO )L@O) [lhw s2 hw+h +u 10 
anpa 

x + 

Step 2: Enter the equation and create the user-defined function. 

feons [cme [PPAR] A |PRTPALIOPAR 
A) GED 


Step 3: Now create a user-defined function BOXR to calculate the 
ratio of surface area to volume. Use the Equation Writer 
application to key in the equation. 


(4) EQUATION) 
BOXR x 

SENHAS Rey z) =o ae) 

aoe BOERS CNA 


Enter the equation and create the user-defined function. 


[EDHE EDH: | CHE [PPAR] A JPRIPA 
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Step 5: Use BOXR to calculate the ratio of surface area to volume 
for a box 9 inches high, 18 inches wide, and 21 inches long. 
Enter the height, width, and length, then execute BONXR. 


9 (ENTER) 18 ( ) 21 li 428571428571 
Te = [Ense [Enss | cme [PPAR | A [PATER 


Note that BONS was defined using h, w, and las variables, and that 
BOXS takes x, y, and z as arguments in the definition for BOXR. It 
makes no difference if the variables in the two definitions match—each 
set of variables is independent of the other. 
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Functions of Real and Complex 
Numbers 


Math Functions on the Main Keyboard 


The following tables describe built-in commands that appear on 


keyboard. 


Arithmetic and General Math Functions 


Hooo 


ş 


Description 


Key Programmable 
Command 
vV 
CEA SQ 
+7 NEG 
+ 


XROOT 


INV Prefix. Inverse (reciprocal). 


Prefix. Square root. 

Prefix. Square. 

Infiz. Change sign. Changes the sign of 
the number in the command line. When 
no command line is present, 
executes a NEG command (changes the 
sign of the argument in level 1). 

Infiz. Level 2 + level 1. 

Infiz. Level 2 — level 1. 

Infiz. Level 2 x level 1. 

Infix. Level 2 + level 1. 

Infiz. Level 2 raised to the level 1 
power. The algebraic syntax for the ^ 
command is ‘yr’. 

Prefix. The zth (in level 1) root of a 
real value in level 2. The algebraic 
syntax for the XROOT command is 


MROOT Crs y). 
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Exponential and Logarithmic Functions 


Key Programmable Description 
Command 
(maon ALOG Prefiz. Common (base 10) 
antilogarithm. 
(>) (LOG) LOG Prefiz. Base 10 logarithm. 
(se) EXP Prefix. Natural (base e) antilogarithm. 
AN LN Prefix. Natural (base e) logarithm. 


Trigonometric Functions 


For trigonometric functions, the angle arguments and results are 
interpreted as degrees, radians, or grads, depending on the current 


angle mode. 


Trigonometric Functions 


Key Programmable Description 
Command 

SIN SIN Prefix. Sine. 
(9) (ASIN) ASIN Prefix. Arc sine. 

cos COS Prefix. Cosine. 
(*) (ACOs) ACOS Prefix. Arc cosine. 

TAN TAN Prefiz. Tangent. 
(#)(ATAN) ATAN Prefix. Arc tangent. 
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Hyperbolic Functions 


Hyperbolic functions are found in the MTH HYP menu ((MTH) 


Key Programmable Description 
Command 
MTH 
SINH Prefix. Hyperbolic sine: (e” — e~*)/2. 
ASINH Prefix. Inverse hyperbolic sine: sinh! 
Ti 
COSH Prefix. Hyperbolic cosine: (e + e~")/2. 
ACOSH Prefix. Inverse hyperbolic cosine: 
cosh! z. 
TARE TANH Prefix. Hyperbolic tangent: 
sinh x/cosh z. 
AUTRE ATANH Prefix. Inverse hyperbolic tangent: 
sinh7}(x/V1— 22). 
Seon i EXPM Prefix. e® — 1. Argument x is in level 1. 


(EXPM is more accurate than EXP 
when the argument to e” is close to 0.) 
LHF I LNP1 Prefix. In (a + 1). Argument x is in 
level 1. (LNP1, In plus 1, is more 
accurate than LN when the argument to 
[in is close to 1.) 
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Probability and Test Statistics 


Use the commands in the PROB (probability) menu (MTH) 


5 
H 


) to calculate combinations, permutations, factorials, random 


numbers, and upper-tail probabilities of various test statistics. 


Probability Commands 


Key 


Programmable 
Command 


Description 


RPLM ES 


OT) OD Fe 


mi 


PERM 


RAND 


RDZ 


Prefix. Number of combinations of n (in 
level 2) items taken m (in level 1) at a 
time. 

Prefix. Number of permutations of n 
(in level 2) items taken m (in level 1) at 
a time. 

Postfix. Factorial of a positive integer. 
For non-integers, ! returns P(x + 1). 
Command. Returns the next real 
number n (0<n<l)ina 
pseudo-random number sequence. Each 
random number becomes the seed for 
the next random number. 

Command. Takes a real number from 
level 1 as a seed for the next random 
number (from RAND). 0 in level 1 
creates a seed based on the clock time. 
A sequence of random numbers can be 
repeated by starting with the same 
nonzero seed. 


Calculating Test Statistics 


Test statistics are calculated using values you enter on the stack— 
they do not use the statistical data stored in SDAT in the STAT 


application. 
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Test Statistics Commands 


Keys Programmable Description 
Command 


(i) GD PROE GD 
Upper-tail chi-square distribution. 


UTEE 

Prefix. Takes the degrees of freedom 
from level 2 and a real number (z) from 
level 1, and returns the probability that 
a x? random variable is greater than z. 


Upper-tail f distribution. Prefix. Takes 
the numerator degrees of freedom from 
level 3, the denominator degrees of 
freedom from level 2, and a real number 
(xz) from level 1, and returns the 
probability that a Snedecor’s F random 
variable is greater than z. 


Upper-tail normal distribution. Prefiz. 
Takes the mean from level 3, the 
variance from level 2, and a real number 
(z) from level 1, and returns the 
probability that a normal random 
variable is greater than z for a normal 
distribution. 

Upper-tail t distribution. Prefix. Takes 
the degrees of freedom from level 2 and 
a real number (z) from level-1, and 
returns the probability that the 
Student’s t random variable is greater 
than z. 

Normal distribution. Prefiz. Takes the 
mean from level 3, the variance from 
level 2, and a real number (z) from level 
1, and returns the density function at z 
for a normal distribution. 


UTR 


Note that, when used as an argument for these commands, the number 
of degrees of freedom must be between 0 and 499. Also, in the 
calculations, the degrees of freedom are rounded to the nearest integer. 
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Example: The scores on a final exam approximate a normal curve 
with a mean of 71 and standard deviation of 11. What 
percentage of the students scored between 70 and 89? 


12 


Step 1: First, calculate the probability that a student chosen at 
random obtained a score greater than 70. (Square the 
standard deviation to get the variance.) 


1: . 226217906697 
[urec [urrF [uren uTPT [Nmr | 


MTH) (NXT) FEGE (NXT 


amn 
D me m 
(3 


Step 2: Now, do the same calculation for a score of 89, after recalling 
the last argument used. 


(ARs) @) 


89 TRH 


et 229621 7 S86697 
1: 3.4081 73247 56E-2 
[uter Luter [uten uretim | 


Step 3: Subtract the two values. About 49% of the students scored 
between 70 and 89. 


O 1: . toss s05 4221 


UTPF | UTPN | UTPT ANDET o 
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Real Number Functions 


Some functions can only use real numbers as arguments. Among these 


are angle conversions, percentages, and several functions that round, 
truncate, or extract parts of real numbers. 


Angle Conversion Functions 


Two commands in the MTH REAL menu convert values between 
decimal degrees and radians. Two other commands in the TIME 
menu let you do degrees-minutes-seconds calculations using 
hours-minutes-seconds (HMS) format. 


In Degrees mode, angle arguments and results use decimal degrees. 


Angle Conversion Functions 


Key Programmable Description 
Command 


MTH) FEAL. (NXT) (NXT): 


Prefix. Degrees to radians. Converts a 
number from a decimal degree value to 
its radian equivalent. 

Porp R—=D Prefix. Radians to degrees. Converts a 
number from a radian value to its 


decimal degree equivalent. 


Omm OD) 


—HMS Decimal to HMS. Converts a number 
from decimal degrees to HMS format. 
HS HMS— HMS to decimal. Converts a number 
from HMS format to decimal degrees. 

HME HMS+ Adds two angles in HMS format. 
Hi HMS— Subtracts two angles in HMS format. 
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The following illustrates the conversion to and from HMS format: 


Decimal Format Hours-Minutes-Seconds Format 
Hours (or degrees) Hours folegegtee>) Seconds 
| NS ee 
1.42673 q 1. 2538228 
iar aoe HMS> 
Fractional hours (or degrees) sities Fractional seconds 
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Example: Convert 1.797 radians to degrees. 


Step 1: First, enter 1.797. 


1.79 
Qaa 


Step 2: Use the R—D function. (The function acts independently of 
the current angle mode.) 


(MTH) REAL 


Ret 


]: '1. rga! 
ec tRlmaTR| List | WYP [REAL [EASE 


1: "RIDCL. Pon! 
LAND [TRNC [FLOUR] CEIL Look | Ret | 


Step 3: Use —NUM to obtain a numeric result. 


ec Pao ener are ETT Teer 


Example: Convert 25.2589 degrees to degrees, minutes, and seconds. 


25.2589 : * 
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Percent Functions 


Percent Functions 


Key Programmable | Description 
Command 
MTH 
% Prefix. A percent of B, or B percent of 
A (A ìs in level 2, B is in level 1): 
(A x B)/100. 
SCH ACH Prefix. The percent change from A to 
B, as a percentage of A (A is in level 2, 
B is in level 1): ((B — A)/A) x 100. 
T HT Prefiz. The percent of total (the total, 
A, is in level 2 and the value, B, is in 
level 1): (B/A) x 100. 


Other Real-Number Functions 


The functions in the following table are found in the MTH REAL 
menu ((MTH) REAL ). 


So Example 
Command / Description 
Input | Output 

ABS Prefix. Absolute Li -iZ i iz 

value. 

CEIL Prefix. Smallest i aa i -3 

integer greater than or equal 
to the argument. 1: 3.5 jl: 4 
| FLOOR, Prefix. Greatest Lk 6.39 7 18 É 

integer less than or equal to 

the argument. i: -6.9 | li me 
| FP Prefix. Fractional part | 13 a. esd EF „23g 

of the argument. | 

i -5.234 | 1 -. 234 
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Command / Description 


IP Prefiz. Integer part of 
the argument. 


fot 


MANT Prefix. Mantissa of 
the argument. 


po 
Di 
i 


MAX Prefiz. Maximum; 
the greater of two 
arguments. 


MIN Prefiz. Minimum; the 
lesser of two arguments. 


MOD Prefiz. Modulo; 
remainder of 4/g. A MOD 
B = A - B FLOOR (4 /z). 


RND Prefix. Rounds 
number according to 
argument: n = 0 to 11 
rounds to n FIX, n = —11 
to —1 rounds to n significant 
digits, and n = 12 rounds to 
current display format. 


SIGN Prefix. Returns +1 
for positive arguments, —1 
for negative arguments, and 
0 for arguments of 0. 


TRNC Prefix. Truncates 
number according to 
argument: n = 0 to 11 
truncates to n FIX, n = 
—11 to —1 truncates to n 
significant digits, and n = 12 
truncates to current display 
format. 


bee fa 


XPON Prefix. Exponent of 


the argument. 
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Complex Numbers 


Most functions that work with real numbers also work with complex 
numbers. So, the way you use complex numbers is similar to the way 
you use real numbers. 


The examples in this section assume the calculator is set to Degrees 
mode. (Press ()(MODES) AHGL DEG to set Degrees mode.) 
12. 


Displaying Complex Numbers 


You can display complex numbers as either rectangular coordinates or 
polar coordinates—in Rectangular mode or in Polar mode. 


To display rectangular coordinates for complex numbers: 
m Press ()(POLAR) until no coordinate annunciator is on. 


or 


m Press (>)(MODES) (¥) (P), then press until Rect angular is 


ma bg 


displayed in the COORD SYSTEM: field. Confirm your selection by 
pressing | OF 

To display polar coordinates for complex numbers: 

m Press ()(POLAR) until the Faz or Fae coordinate annunciator is 


on. 


or 
m Press (¢>)(MODES) (¥) (F), then press until Falar is displayed 
in the COORD SYSTEM: field. Confirm your selection by pressing 
Te 

Even though only two coordinate modes are needed for complex 
numbers, three coordinate modes are available on the HP 48 (to 
provide for three-dimensional vectors)—Rectangular mode, Polar 
(cylindrical) mode, and Spherical mode. 


Complex numbers are displayed inside parentheses. In rectangular 
form, the real and imaginary parts are separated by a comma. (If 
the Fraction Mark is set to comma, they’re separated by a semicolon 
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instead.) In polar form, the magnitude and phase angle are separated 
by a comma and angle sign (£). (The angle is based on the current 
angle mode: Degrees, Radians, or Grads.) Regardless of how complex 
numbers are displayed, the HP 48 stores them internally in rectangular 
form. 


Display Modes 


Rectangular | Polar | 
Real axis e ~= | 


(a,b) (, <0) 


Imaginary axis 


Entering Complex Numbers 


You can enter complex numbers using either rectangular coordinates 
or polar coordinates. 


To enter a complex number: 


m To enter rectangular coordinates, press (€)(()), enter the 


coordinates separated by or (#)(), and press (ENTER). 
m To enter polar coordinates, press (€)(()), enter the coordinates 


separated by (@)(4), and press (ENTER). 


The internal rectangular representation of all complex numbers has 
the following effects on polar numbers: 


a 0 is normalized to the range +180° (+r radians, +200 grads). 


m If you key in a negative r, the value is made positive, and @ is 
increased by 180° and normalized. 


a If you key in an r of 0, @ is also reduced to 0. 
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Real Calculations with Complex Results 


The complex-number capabilities of the HP 48 can affect the results 
of real-number operations. Certain calculations that would result in 
an error on most calculators yield valid complex results on the HP 48. 
For example, the HP 48 returns a complex number for the square root 
of —4. Also, the arcsine of 5 yields a complex result. 


You'll find that for most calculations, the HP 48 gives you the type of 
result (real or complex) you expect. However, if you find that you get 
complex results when you expect real results, check your program or 
keystrokes for these potential causes: 


w The data you supplied to the calculator may be outside the range of 
the formula you are calculating. 

w The formula (or its execution) may be incorrect. 

wa A rounding error at a critical point in the formula may have 
compromised the computation. 

m A complex result may be unexpected, but correct, for your problem. 


Other Complex-Number Commands 


Most commands that operate on real numbers also operate on complex 
numbers (such as SIN, INV, ^, and LN). The following table describes 
additional commands that are especially useful for complex numbers. 


The remaining commands are found in the MTH CMPL menu (press 


CMPL 


oe Example 
Command / Description ee pees 
Input Output 
ABS Prefiz. Absolute ih: Hagi i: = 
value; 4/ £? + y?. 
ARG Prefiz. Polar angle of | i: isis i 43 
| a complex number. 
CONJ Prefiz. Complex 1: Cay So i: Cea 50) 
conjugate of a complex 
number. | 
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Command /Description 


Example 


to real; separates a complex 
number into two real 
numbers, the rectangular 
coordinates x and y. 


ee Sa l 
| C—R Command. Complex | 


IM Prefix. Imaginary (y) 
part of a complex number. 


NEG Infiz. Negative of its 
argument. 


RE Prefix. Real (x) part of 
a complex number. 


Ñ 
i 
i 

es 


R-—C Command. Real to 
complex; combines two real 
numbers into a complex 
number (x,y). 


SIGN Prefix. Unit vector 
in the direction of the 
complex number argument; 


(Jenn Yor? 


É a È aon pa 
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Vectors and Transforms 


All vectors are array objects. The general case of n-dimensional 
vectors is covered in chapter 14, “Matrices and Linear Algebra” —this 
chapter deals primarily with 2D and 3D vectors. 


You can display 2D vectors as either rectangular components 
(E: X Y 3) or polar components (E R & 1)—in Rectangular mode or 
in Polar mode. 


y 
x a l Two-Dimensional Display Modes 
AT Ta Rectangular Polar 
b AL | 8 \ — 
i S ee” | [a b] [r <0] 
| 
i 


2D Vector Components 


You can display 3D vectors as rectangular components (E X Y Z 1), 
cylindrical components (E R & Z 1), or spherical components 

(€ RA A ł)-in Rectangular mode, in Cylindrical mode, or in 
Spherical mode. 
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“ow Three- Dimensional T Modes 


r Rectangular Cylindrical Spherical | 


[abc] [rxy <8 c] | oa 


3D Vector Components 


Polar mode is actually two modes—Cylindrical mode and Spherical 
mode. For 2D vectors, Cylindrical and Spherical modes are 
interchangeable—both give the same two-dimensional results. 


To display rectangular components: 


m Press (@)(POLAR) until no coordinate annunciator is on. 
or 


m Press VECTR REET. 
To display polar (cylindrical or spherical) components: 


a Press (@)(POLAR) until the Raz or Ras coordinate annunciator is 
on. 


m Press VECTE CYLIH (for cylindrical/polar) or 
SPHER (for eai 


The æ in the menu label, and the coordinate annunciator, indicate the 
active coordinate mode: 


222 annunciator 
£ annunciator 


Vectors are displayed inside E J] delimiters. In rectangular form, the 
components are separated by spaces. In polar (cylindrical or spherical) 
form, angles are preceded by an angle sign (£). (The angle is based on 
the current angle mode: Degrees, Radians, or Grads.) Regardless 
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of how vectors are displayed, the HP 48 stores them internally in 
rectangular form. 


If you enter one type of coordinates, you can simply change the 
coordinate mode to convert vectors to the new coordinate mode. 


Entering 2D and 3D Vectors 


You can enter 2D and 3D vector components using rectangular, 
cylindrical/polar, or spherical/polar form. 


To enter a 2D or 3D vector: 


a To enter specific components, press (|), enter the components 
separated by or (¢>)(4), and press (ENTER). (Press @)(4) 
just before each angular component.) 

m To use the current coordinate mode, enter the two or three 
component values and press VECTRE #2 or 4¥ 
(Don’t enter £.) 


The internal rectangular representation of all vectors has the following 
effects on displayed polar (cylindrical and spherical) vectors: 


a @ is normalized to within +180° (47 radians, +200 grads). 
m ¢ is normalized to within 0 to 180° (0 to r radians, 0 to 200 grads). 


m If you key in a negative r, the value is made positive; @ is increased 
by 180°, @ is subtracted from 180°, and both are normalized. 


m If @ is 0° or 180°, @ is reduced to 0°. 


m If you key in an r of 0, 0 and ¢@ are reduced to 0°. 


To assembie a 2D or 3D vector from components on the stack: 


a Fora 2D Nee enter a component on level 1 and level 2, press 
(MTH) VERT +2 | The components are interpreted according 
to the burren SEEI mode. 

a For a 3D vector, enter a component on level 1, level 2, and level 
3, press . The components are interpreted 
according to ve current coordinate mode. 
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To take apart a 2D or 3D vector on the stack: 


m Press SECTE = . The returned values are the same as 
the displayed components. 


Vector Math Commands 


A vector, like a real number, is a single object. So you can use vectors 
as arguments for commands. You can add and subtract vectors— 

you can multiply and divide vectors by scalars—-and you can execute 
special vector commands (DOT, CROSS, and ABS). These special 
commands interpret their arguments and return results using the 
current coordinate mode and can be found in the MTH VECTR 


menu((MTH) WECTR). 


Example 


Command / Description 
Input Output 


ABS Prefix. Returns the i:f 2-3 4 ] 1: 3.385 184e 
scalar magnitude of vector, 
calculated as the Frobenius 
norm—-defined as the square 
root of the sum of the 
squares of the absolute value 
of each element. 


DOT Command. Returns 
the inner or dot product (a 
scalar) of two vectors of 
equal dimensions. 


rer 


Laced Boal 
pa 
su 
fa 
i 


bebe Pi 


CROSS Command. 23: [Ż353 4] L:f-3 -6 Fo] 
Returns the cross product (a | iff -1 2 1 ł 
3D-vector) of two vectors. 
Two element vectors will 
have a third zero element 
added during execution. 
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Additional commands for manipulating vectors and elements of vectors 
are covered in chapter 14. 


Examples: Calculating with 2D and 3D Vectors 


To calculate with vectors: 
ma Enter the vectors on the stack, then execute the command. 


Example: Finding the Unit Vector. A unit vector parallel to a given 
vector is found by dividing a vector by its magnitude: 
v 


[v] 


1. Enter the vector. 


2. Duplicate the vector (press a second time). 
3. Press YECTE ABZ to compute the magnitude of the 


vector. 
4. Press (£) to divide the vector by its magnitude to get the unit 
vector. 


Example: Finding the Angle between Vectors. The angle between 
two vectors is given by 


zi | v1- V2 | 
angle = cos 


[vaj [V2] 


Enter the two vectors onto the stack. 

Press WECTR DOT to take the dot (inner) product. 

Press (¢)(ARG) to return the two vectors to the stack. 

Press ABS. (4) AES — to find the magnitude of each 

vector. 

5. Press (x) to multiply the magnitudes. 

6. Press ($) to divide the product of the magnitudes into the dot 
product. 

7. Press (4,)(ACOS) to find the angle between the vectors. 


A Ne 
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Example: Finding the Component in One Direction. The following 
diagram represents three 2D vectors. Find their sum, and 
then use DOT to resolve them along the 175° line. (This 
example assumes Degrees mode is active.) 


r 185 < 629 
170 < 143 


175° 


13 


100 < 261° 


Step 1: Set Polar-cylindrical mode, enter the three vectors, and find 


their sum. 
VECTR @RDCVLIN |l: [_178,937160532 
H0 170 AE) 143 (ENTER) £111. 148994255 ] 
C) 185 IES 62 (ENTER) a BR a ee 
AO 10 OB #1 OB 


Step 2: Enter the unit vector of 175°, and find the magnitude of the 
resultant vector along the 175° line. 


11 Z) 175 (ENTER 1: 79. 6985649585 
he oS) reer 1 Paes | oor [erosa] vo [ave [ova | 
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Fast Fourier Transforms 
A physical process can be described in two distinct ways: 


m The change of a quantity, h, as a function of time, t (h(t)). 
m The change of an amplitude, H, as a function of frequency, f (A(f)). 


For many situations, it helps to consider h(t) and H(f) as two different 
representations of the same function. Fourier transforms are used to 
switch between these representations, or domains. 


The HP 48 can perform discrete Fourier transforms, whereby a 
sequence of discretely sampled data can be transformed into the 
“other” domain. The HP 48 performs “Fast” Fourier transforms, 
which make use of computational efficiencies that require that the 
number of rows and the number of columns in the sample set to be a 
integral power of 2. 


Fast Fourier transforms are most commonly used in analyzing 
one-dimensional signals or two-dimensional images. The HP 48 
commands can handle both cases. In the first case the data should be 
entered as a vector of N elements where N is an integral power of 2 (2, 
4, 8, 16, 32,... ). In the second case, the data should be entered as 

a matrix of M rows by N columns where both M and N are integral 
powers of 2. 


The “forward” transformation (FFT) maps an array of MxN real or 
complex numbers (hx) in the time domain to an array of MXN real or 
complex numbers (Hn) in the frequency domain: 


N-1 
H, = À hye rikn/N 
n=0 


The “inverse” transformation (IFFT) maps an array of MxN real or 
complex numbers (Hn) in the frequency domain to an array of MxN 
real or complex numbers (hx) in the time domain: 


1 N-1 
x 5 Leroy 
k=0 


hn 
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To prepare an array for fast Fourier transforms: 


1. 


Put the array of data on the stack. 


2. If necessary, add zeros to the array so that all dimensions are equal 


to an integral power of two. See chapter 14 for efficient ways to add 
columns or rows of zeros to matrices. 


To use a fast Fourier transform: 


k 


Enter the array of data to be transformed (or its name) onto 
the stack. Make sure its dimensions are integral powers of 2 (see 
above). 


. Press FFT FFT to transform the data from the 


time domain to the frequency domain. 


or 
Press FFT IFFT to transform the data from the 


frequency domain to the time domain. 


Example: Using FFT and IFFT for forward and inverse fast Fourier 


transforms. The example uses the elements of a random 
vector to represent a sampled signal. 


Create a 16-element random vector on the stack: enter {i823 RAHM. 
Compute the one-dimensional discrete Fourier transform of this 
signal: execute FFT. The elements of the resulting vector represent 
the frequency components of the original signal. 

Reconstruct the original signal by computing the one-dimensional 
inverse discrete Fourier transform: execute IFFT. The result is the 
same as the original signal, subject to small rounding errors. 


You can compute two-dimensional Fourier transforms using matrices 
as arguments. For instance, use a random 16x16 matrix in the above 
example: 116 163 RAHM. 
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Matrices and Linear Algebra 


The HP 48 has extensive capabilities for entering and manipulating 
arrays. Array objects represent both vectors and matrices. Many 

of the operations described in this chapter also apply to vectors. 
Wherever this is the case, the more general term array is used instead 
of matriz. 


Creating and Assembling Matrices 


You can enter a matrix two ways: 


m MatrixWriter application. A visual method of entering, viewing, and 
editing array elements. 


m Command line. The basic object-entry method. 


To enter a new matrix using the MatrixWriter: 
1. Press (>)(MATRIX) to display the MatrixWriter screen and menu. 


2. For each element in the first row, do one of the following: 

m Type the real or complex number and press (ENTER). You cannot 
mix real and complex elements in the same matrix. 

m Compute the element using the command line and press (ENTER). 
To compute an element, type in the arguments (press to 
separate arguments) and press the desired function keys. 

3. Press (¥) to mark the end of the first row (which specifies the 
number of columns in the matrix). 

4. For each element in the rest of the matrix, either type in a value or 
compute it in the command line and then press (ENTER). Or, if you 
wish, enter numbers into more than one cell at a time by typing 
them all into the command line (pressing to separate each 
number), and then pressing once to enter them all. 
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5. After you've entered all of the numbers in the matrix, press (ENTER 


to put the matrix on the stack. 


For more details about using the Matrix Writer, see chapter 8. 


To enter a matrix using the command line: 
1. Press (p) (0) and (e) to type the delimiters for the matrix and 


for the first row. 
2. Key in the first row. Press to separate the elements. 
Press (>) to move the cursor past the J] row delimiter. 
4. Optional: Press (->)() (new line) to start a new row in the 
display. 
Key in the rest of the matrix. You don’t need £ J delimiters for 
subsequent rows-——-they’re added automatically later. 


6. Press (ENTER). 


The HP 48 has built-in commands to automatically create special 
matrices that are often used in conjunction with matrices you create 
element by element. 


Ww 


on 


To create an array filled with a given constant: 


1. Enter one of the following onto the stack: 
a A list containing the dimensions of the desired constant array: 
€ rows columns =. 
m Any array whose elements you don’t mind changing. 
2. Enter the constant that you want in the array. 
3. Press MATE MAEE COM. This returns an array of the 
same dimensions as you entered (or that the argument array had) 
filled with your chosen constant. 


To create an identity matrix: 


1. Enter one of the following onto the stack: 

m A real number representing the number of rows and columns 
you want in the square identity matrix (fractional values are 
rounded). 

m Any square matrix whose elements you don’t mind changing. 

2. Press MATE MAKE LEH. Returns a square identity 


matrix of the given dimensions. 
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To create an array filled with random integers: 


1. Enter one of the following onto the stack: 

m A list containing the dimensions of the desired random array: 
© rows columns *}. 
m Any array whose elements you don’t mind changing. 

2. Press HATE EE- R . Returns a random array 
have the dimension specified by the list or array argument. The 
array elements are all integers in the range [-9 9]. Each integer is 
as likely as any other except for 0, which is twice as likely as the 
others. 


To assemble a matrix by rows from a series of vectors: 


1. Enter each vector onto the stack in the order you want them to 
appear in the matrix. Enter the row 1 vector first, then the row 2 
vector, and so forth, entering the bottom row vector last. 


2. Enter the number of rows in the desired matrix. 
3. Press HATE RG. ROH to assemble the vectors into a 


matrix. 


To assemble a matrix by columns from a series of vectors: 


1. Enter each vector onto the stack in the order you want them to 
appear in the matrix. Enter the column 1 vector first, then the 
column 2 vector, and so forth, entering the right-most column 
vector last. 

2. Enter the number of columns in the desired matrix. 

3. Press MATE. CÉL COL to assemble the vectors into a 
matrix. 


To assemble a matrix with a particular diagonal from a vector: 


1. Enter the vector containing the diagonal elements. 
2. Enter one of the following: 
m A list containing the dimensions of the desired matrix: 
£ rows columns 3. 
a A real number representing the number of rows and columns in 
the desired square matrix. 

3. Press TR i :# to create a matrix of the 
desired dimensions using the elements of the diagonal vector as 
the diagonal elements of the matrix. If the vector contains more 
diagonal elements than are needed to create the matrix, the extra 
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elements are discarded. If the vector does not contain enough 
elements to complete the matrix, the undefined diagonal elements 
are set to zero. 


Disassembling Matrices 

The HP 48 assembles and disassembles the elements of a 
two-dimensional matrix according to row-major order. Beginning 
with the first element (the element in row 1 and column 1), row-major 
order assumes that the “next” element is the next one in the row. If 
there are no more elements in the row, then the “next” element is the 
first element in the next row. The row-major convention thus works 
much like a left-to-right word processor that fills up (or removes) one 
line before “wrapping around” to the beginning of the next line. 


To disassemble a matrix into its elements: 

1. Enter the matrix onto the stack. 

2. Press TYFE G44 . The matrix is disassembled in 
row-major order, leaving each element on its own stack level. Level 
1 contains a list of the original dimensions of the matrix. 


To assemble a matrix from a sequence of elements: 


1. Enter the elements onto the stack in row-major order. 
2. Enter a list containing the dimensions of the desired matrix: 
© rows columns *. 


3. Press TYRE +ARE- to assemble the matrix. 


To disassemble a matrix into row vectors: 


1. Enter the matrix onto the stack. 

2. Press WATE: ROM +O. The matrix is disassembled 
into row vectors (first row to last). Level 1 of the stack contains a 
real number representing the number of rows in the original matrix. 


To disassemble a matrix into column vectors: 


1. Enter the matrix onto the stack. 
2. Press HATE COL- COL. The matrix is disassembled 
into column vectors (first column to last). Level 1 of the stack 
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contains a real number representing the number of columns in the 
original matrix. 


To extract the vector of diagonals from a matrix: 


1. Enter the matrix onto the stack. 


2. Press FETAC 


elements as a vector. 


to extract the diagonal 


Inserting Rows and Columns 


To insert one or more new rows into a matrix: 


1. Enter the target array—the one you wish to modify—onto the 
stack. 

2. Enter the vector, matrix, or element (when the target array is a 
vector) you want to insert. An inserted array must have the same 
number of columns as the target matrix. 

3. Enter the row number where you want the first (or only) inserted 
row to be. The elements currently located in that row, and in all 
rows below, will be shifted down to accommodate the insertion. 
Row numbers start at 1, not 0. 

4. Press MATE ORO ROLE to insert the new row(s). 


To insert one or more new columns into an array: 


1. Enter the target array—the one you wish to modify—onto the 
stack. 

2. Enter the vector, matrix, or element (when the target array is a 
vector) that you wish to insert. An inserted array must have the 
same number of rows as the target array. 

3. Enter the column number where you want the first (or only) 

inserted column to be. The elements currently located in that 

column, and in all columns to the right, will be shifted right to 

accommodate the insertion. Column numbers start at 1, not 0. 


. Press p 


Aa 


perp 


Coo OOL+ to insert the new columns. 
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Extracting Rows and Columns 


To extract a particular row from an array: 


1. Enter the array onto the stack. 

2. Enter the row number (or element number if the array is a vector) 
that you wish to extract. 

3. Press HATE FO. —OW- . The extracted row vector 
(or element) is returned to level 1 and the contracted array—with 
the row or element deleted—is returned to level 2. 


To extract a particular column from an array: 


1. Enter the array onto the stack. 

2. Enter the column number (or element number if the array is a 
vector) that you wish to extract. 

3. Press (MTH) HATE COL OL- . The extracted column 
vector (or element) is returned to level 1 and the contracted 
array—with the column (or element) deleted—is returned to 
level 2. 


Swapping Rows and Columns 


To swap the location of two rows in an array: 


1. Enter the array onto the stack. If the array is a vector, it is 
considered to be a column vector. 

2. Enter the two row numbers that are to be swapped. 

3. Press MATER KOH (NXT) ESHP . The modified array is 


returned to level 1. 


To swap the location of two columns in an array: 


1. Enter the array onto the stack. If the array is a vector, it is 
considered to be a row vector. 

2. Enter the two column ampere that are to be swapped. 

3. Press NATE CEH . The modified array is 


returned to level 1. 
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Extracting and Replacing Elements of Matrices 


To extract the array element at a specified position: 


1. Enter the array onto the stack. 
2. Enter one of the following: 
a A list containing the row and column number of the element you 
wish to extract: £ row column +. 
a The position number of the element you wish to extract. (For 
matrices, this is interpreted as row-major order.) 
3. Press NATE WARE GET to extract the specified 


array element. 


To replace an array element at a specified position: 


1. Enter the array onto the stack. 
2. Enter one of the following: 
a A list containing the row and column number of the element you 
wish to replace: € row column 3. 
a The position number of the element you wish to replace. (For 
matrices, this is interpreted as row-major order.) 
3. Enter the new replacement element. 
4. Press HATER MARE FUT to replace the element 


at the specified location with the new element. 


Characterizing Matrices 


Matrix calculations are often sensitive to special characteristics of the 
matrices used. The HP 48 has a number of commands that return 
characteristics of matrices. Note that some commands are only defined 
for square matrices, some for any rectangular matrix. 


Matrices and Linear Algebra 14-7 


14 


Commands for Characterizing Matrices 


Key Programmable Description 
Command 
HATE MAKE 
SIZE SIZE Command. Returns the dimensions of 


the array on level 1 of the stack. 


HORM: 


SHEN 


RMR 


CHEN 


ABS 


SRNM 


RNRM 


CNRM 


Prefiz. Returns the Frobenius norm of a 
matrix and the Euclidean length of a 
vector: the square root of the sums of 
the squares of the absolute values of the 
elements. 

Command. Returns the spectral norm 
of an array. The spectral norm of a 
matrix is equal to the largest singular 
value of the matrix. Same as ABS for a 
vector. 

Command. Returns the row norm of an 
array. The row norm of a matrix is the 
maximum value (over all rows) of the 
sums of the absolute values of all 
elements in a row. The row norm of a 
vector is the maximum absolute value of 
its elements. 

Command. Returns the column norm of 
an array. The column norm of a matrix 
is the maximum value (over all 
columns) of the sums of the absolute 
values of all elements in a column. The 
column norm of a vector is the sum of 
the absolute values of its elements. 
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Commands for Characterizing Matrices (continued) 


Key Programmable Description 
Command 
SRAD SRAD Command. Returns the spectral radius 


of a square matrix. The spectral radius 
is the absolute value of the largest 
eigenvalue of the matrix. 

COH COND Command. Returns the column-norm 
condition number of a square matrix. 
The condition number is defined to be 
the product of the column norm of a 
square matrix and the column norm of 
its inverse. 

RAHE RANK Command. Returns an estimate of the 
rank of a matrix. The rank of a matrix 
is equal to the number of nonzero 
singular values of the matrix. If Flag 
—54 is clear (default), RANK treats any 
computed singular value less than 10°! 
times the size of the largest computed 
singular value as zero. If Flag —54 is 
set, RANK counts all nonzero singular 
values no matter their size. 

DET DET Command. Returns the determinant of 
a square matrix. DET checks flag —54, 
and will refine its computed value only 
if —54 is clear (default). 

TRACE Command. Returns the trace of a 
square matrix. The trace of a matrix is 
equal to the sum of the diagonal 
elements and also equal to the sum of 
the eigenvalues of the matrix. 
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To transpose a matrix: 


1. Enter the matrix onto the stack. 

2. Press HATE MAREE TEH to transpose the matrix. The 
first row of the original matrix is now the first column, the original 
second row is now the second column and so forth. This computes 
the conjugate transpose of complex matrices. 


To invert a square matrix: 


1. Enter the square matrix. 

2. Press to invert the matrix. Note that matrix inversion can 
produce erroneous results if you are using ill-conditioned matrices. 
See “Ill-Conditioned and Singular Matrices” on page 14-16. 


To change the dimensions of an array: 


1. Enter the array onto the stack. 

2. Enter a list containing the new dimensions of the array: 
< rows columns ¥. 

3. Press HATE MAKE RDP to redimension the array. 
Elements from the original array are placed in row-major order into 
the newly-dimensioned array. If there are fewer elements in the new 
array than in the original one, the excess elements are dropped. If 
there are more elements in the new array than in the original one, 
the missing elements are filled with zeros (or <6, 2 if the array is 
complex). 


14-10 Matrices and Linear Algebra 


Calculating with Matrix Elements 


To add or subtract two matrices: 


1. Enter the two matrices onto the stack in the same order as you 
would to add or subtract real numbers. They must have the same 
dimensions. 

2. Press to add or ©) to subtract. The single resulting matrix 
has elements that are the sum or difference of the corresponding 
elements in the original argument matrices. 


To multiply or divide a matrix by a scalar: 


1. Enter the matrix onto the stack. 

2. Enter the scalar (a real or complex number). 

3. Press (x) or Œ). Each element of the resulting matrix is the product 
or quotient of the scalar and the corresponding element in the 
original argument matrix. 


To change the sign of each element in a matrix: 


1. Enter the matrix onto the stack. 
2. Press to change the sign of each element in the matrix. 


To find the matrix product (AB) of two matrices: 


1. Enter the two matrices onto the stack. Be careful about the entry 
order because matrix multiplication is not commutative. Enter 
matrix A first and matrix B second. Remember also that the 
number of columns in A must equal the number of rows in B. 

2. Press (x). The result will be a matrix with the same number of 
rows as A and the same number of columns as B. 


To multiply a matrix and vector: 


1. Enter the matrix onto the stack. 

2. Enter the vector. The number of elements in the vector must equal 
the number of columns in the matrix. 

3. Press (x). The result will be a vector with as many elements as the 
number of rows in the original matrix. 
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To “divide” an array by a square matrix: 


1. Enter the array onto the stack. 

2. Enter the square matrix. The number of rows in the matrix must 
equal the number of rows in the array (elements in the vector). 

3. Press Œ) to calculate Y-X~!. The result will be a vector of the 
same size as the original. Note that array division can produce 
erroneous results if you are using ill-conditioned matrices. See 
“Ill-Conditioned and Singular Matrices” on page 14-16 . 


Using Arrays and Array Elements in Algebraic 
Expressions 


You can perform calculations with array elements using algebraic 
syntax. The array must be represented by a name in the symbolic 
expression or equation. 


To use a matrix element in an algebraic expression: 


1. Make sure that the array is stored in a named variable. 
2. Create the algebraic expression and, at the point where the matrix 
element is to be used, type the array name and press oW. 
3. Enter the subscripts for the element: 
a For a vector, enter one subscript (position number of the 
element). 
m For a matrix, enter two subscripts separated by ()() (row and 
column numbers of the element). 


Example: Enter a symbolic expression for the sum of all elements of 
a 2 x 5 matrix stored in MATR. 


Step 1: Begin the expression. 


(&) EQUATION) 
OOO) 5182 
OD OE) k 1 8)5 
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Step 2: Enter the name of the matrix and the subscripts. 


(a}(hold)MATR (release) 


HOOD! BOOM) l 
K , MATRCJ, k) O 


HATA] LIST | HYP | REAL | EASE | 


Step 3: Press (ENTER) to put the expression on the stack. Assuming 
that the 2 x 5 matrix is already stored in MATR, press 


EVAL) to compute the sum of its elements. 


To apply a mathematical function to each element in an array: 


1. Enter an array. 

2. Enter a program that contains a function. The program must take 

one argument and give one result. 

Type TEACH and press (ENTER). 

4. Press (VAR) EANO PEGS AFLY . The function is applied to 
each element, and the result replaces that element. If the applied 
function returns an algebraic for one of the elements, then the array 
is returned in list format. 


o 


Transforming Complex Matrices 


To combine two matrices into a complex matrix: 


1. Enter the real matrix that will become the real part of the complex 
matrix. 

2. Enter the real matrix that will become the imaginary part of the 
complex matrix. 


3. Press (MTH) (NXT) £ 


| f to combine the two real 
matrices into a complex matrix. 


To split a complex matrix into two real matrices: 


1. Enter the complex aus on the stack. 
2. Press (MTH) Cop HEL E+E- to split the complex matrix into 
its real and imaginary pae 
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To conjugate each element of a complex matrix: 


1. Enter the complex matrix onto the stack. 


2. Press (MTH) (NXT) APL LOH to conjugate each 


complex element of the matrix. 


To extract a matrix of real parts from a complex matrix: 


1. Enter the complex matrix onto the stack. 
2. Press (MTH) CMPL RE. to return a matrix containing 
just the real parts of each element of the original complex matrix. 


To extract a matrix of imaginary parts from a complex matrix: 


1. Enter the complex matrix onto the stack. 


2. Press CHEL IM. to return a matrix containing 


just the imaginary parts of each element of the original complex 
matrix. 


Matrix Solutions to Systems of Linear 
Equations 


Systems of linear equations fall into three categories: 


a Over-determined systems. These systems have more linearly 
independent equations than independent variables. There is 
no exact solution to over-determined systems, so the “best” 
(least-squares) solution is sought. 

a Under-determined systems. These systems have more independent 
variables than linearly independent equations. There are either no 
solutions or an infinite number of solutions for under-determined 
systems. If a solution exists, you want to find the solution with the 
minimum Euclidean norm; otherwise, you want to find a minimum 
norm least-squares solution. 

a Exactly-determined systems. These systems have an equal number 
of independent variables and equations. Usually (but not always), 
there is a single exact solution for exactly-determined systems. (See 
“Ul-Conditioned and Singular Matrices” on page 14-16.) 
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To calculate the “best” solution to any system of linear equations: 


1. Press (@)(SOLVE) (A) (A) GE to open the SOLVE SYSTEM A" H=E 
input form. 

2. Enter the matrix of coefficients into field Fe. 

Enter the array (vector or matrix) of constants into field E=. 

4. Press STILE to calculate the “best” solution and display it in 
the 1 field. If the system being solved is exactly-determined, the 
solution is a 12-digit approximation of the exact solution; if it is 
over- or under-determined, then the solution is the minimum norm 
least-squares solution (to 12 digits). 


oa 


To estimate the solution to an over-determined system of linear 
equations: 


1. Enter the array (vector or matrix) of constants onto the stack. 

2. Enter the matrix of coefficients. It will typically have more rows 
than columns. 

3. Press MATE Lm- to calculate the “least-squares 
solution” (X) that minimizes the residual (AX—B) (the minimized 
Euclidean norm of the columns). 


To estimate the solution to an under-determined system of linear 
equations: 


1. Enter the array (vector or matrix) of constants onto the stack. 

2. Enter the matrix of coefficients. It will typically have more columns 
than rows. 

3. Press HATE- LAG to calculate the one “least-squares 
solution” (X) of many possible least-square solutions that has the 
smallest Frobenius norm. 


To solve an exactly-determined system of linear equations: 


1. Enter the vector of constants onto the stack. 

2. Enter the square matrix of coefficients. The number of columns 
(“variables”) in the matrix must equal the number of elements in 
the vector. 

3. Press Œ). The result will be a solution vector of the same size 
as the constants vector. Note that array division can produce 
erroneous results if you are using ill-conditioned matrices. See 
“Tli-Conditioned and Singular Matrices” below. 
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lll-Conditioned and Singular Matrices 


A singular matrix is a square matrix that doesn’t have an inverse. 

You normally get an error if you use to find the inverse of a 
singular matrix—or use @) to solve a system of linear equations having 
a singular coefficient matrix. 


The most common cause of singular matrices are equations within a 
system of linear equations that are linear combinations of one another. 
That is, the coefficients of one equation can be computed exactly 
from the coefficients of the other. Two equations thus related are 
linearly dependent and the set of equations as a whole referred to as 
dependent. 


If a set of equations is independent, but small changes in their 
coefficients would make them dependent, then the set of equations 
(and their corresponding matrix A) are said to be ill-conditioned. 


To determine if a matrix is ill-conditioned: 


1. Enter the matrix onto the stack. 

2. Compute its condition number: Press MATE NORM 
CONG. [fit is large, then it is ill-conditioned. If the condition 
number is on the order of 101", the HP 48 may not be able to 
distinguish it from a singular matrix. 


To use ill-conditioned matrices in solving systems of linear equa- 
tions: 


1. Set flag -22: Press (€;)(MODES) 22 FLAG SF. This is 
the Infinite Result Exception flag that will keep you from getting 
an error using a singular matrix. 

2. Solve the system of linear equations. The HP 48 perturbs the 
singular matrix by an amount that’s usually small compared to the 
rounding error. The calculated result corresponds to that for a 
matrix close to the original, ill-conditioned matrix. 

3. Determine the accuracy of the computed solution using the 
condition number as you would for any ill-conditioned matrix (see 
“Determining the Accuracy of a Matrix Solution” below. 

4, Compute the residual to test your results. 

Resolve the system of linear equations using LSQ. 


wI 
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Determining the Accuracy of a Matrix Solution 


There are two approaches to evaluating the accuracy of a computed 
matrix solution when you suspect that you may be using singular or 
ill-conditioned matrices: 


Compute the residual array. This array is the result of substituting 
the computed solution back into the original equation. The closer 
the residual array is to being an array of zero elements, the more 
accurate the solution. 


Use the condition number. The condition number can be used to 
estimate the number of accurate digits that can be expected using a 
given matrix. 


To find the residuals for a computed solution to a system of linear 
equations (AX=B): 


1. 
. Enter the matrix of coefficients (A). 


Enter the array (vector or matrix) of constants (B) onto the stack. 


Enter the computed solution array (must be of the same type and 
dimensions as the constants array)(X). 


. Press either (MTH) MATE RSC (or @4)GOWE) SYS 


RSD). The resulting array of residuals (AX-B) shows how close 
the computed solution was to an actual solution—the smaller the 
absolute value of the elements, the better the solution. 


To approximate the number of accurate digits in a computed 
solution: 


i 


If the elements in the matrix A are exact, enter 15, the maximum 
number of digits computed internally by the HP 48, onto the 
stack. If the elements in matrix A were rounded to 12 digits (from 
previous computations, for example), then enter 12. 

Enter the matrix of coefficients (A). 

Press HATE HORM. COHD- to find the condition number 
of the matrix. 

Press (>)(LOG) (-) to find the approximate number of accurate 
digits in a solution computed using the given matrix of coefficients. 
This is merely a rough, rule-of-thumb estimate of a solution’s 
accuracy and not a precise computation of it. 


Matrices and Linear Algebra 14-17 


14 


14 


Operations 


The systematic process, known as Gaussian elimination is one of the 
most common approaches to solving systems of linear equations and 
to inverting matrices. It uses the augmented matrix of the system 

of equations, which is formed by including the vector (or vectors) of 


constants ([b; ... bm]) as the right-most column (or columns) of the 
matrix of coefficients ([az; ... @mn]): 

ai a2 age am bi 

a2 a22 az è . am bə 

a3ı a32 a33 -- agn b3 

@m1 äm ms oe amn Dm 


To create an augmented matrix: 


1. Enter the matrix to be augmented (the matrix of coefficients in the 
context of Gaussian-elimination). 

2. Enter the array to be inserted (the array of constants in the context 
of Gaussian-elimination). It must have the same number of rows as 
the matrix. 

3. Enter the last column number, n, of the matrix to be augmented in 
order to indicate where to insert the array. 

4. Press HATES CEOS EOE. 

Once you have an augmented matrix representing a system of linear 

equations, then you can proceed with the Gaussian-elimination 

process. The process seeks to systematically eliminate variables 

from equations (by reducing their coefficients to zero) so that the 

augmented matrix is transformed into an equivalent matrix, from 

which the solution can be easily computed. 


Each coefficient-elimination step depends on three elementary row 
operations for matrices: 


m Interchanging two rows. 
mw Multiplying one row by a nonzero constant. 
a Addition of a constant multiple of one row to another row. 
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Gaussian elimination uses elementary row operations to convert the 
augmented matrix to the equivalent row-reduced echelon matrix, from 
which the solution can be computed by back-substitution. 


The HP 48 offers commands for each of these elementary row 
operations by themselves and one that uses these row operations 
repeatedly until the row-reduced echelon form is generated: 


a RSWP interchanges two rows of a matrix. 

æ RCI multiplies each element in a given row of the augmented matrix 
by a scalar of your choosing. 

a RCIJ multiplies each element in a given row by a scalar and adds 
the result to another row of the matrix. 

m RREF converts an augmented matrix into the equivalent 
row-reduced echelon form. 


To interchange two rows of a matrix: 


1. Enter the matrix onto the stack. 
2. Enter the numbers of the two rows to be interchanged. 


3. Press MATE ROW RSWF . 


To multiply the elements of a row of a matrix by a nonzero factor: 


1. Enter the array onto the stack. 

2. Enter the nonzero factor. 

3. Enter the number of the row to be multiplied. 
4. 


Press MATE ROM RGI 


To add the product of a nonzero factor and one row of an array to 
another row: 


Enter the array onto the stack. 

Enter the nonzero factor. 

Enter the number of the row to be multiplied by the factor. 

Enter the number of the row to which the product is to be added. 


Press HATE ROHO ROT. 


GT RS SBS et 
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To compute the row-reduced echelon form of a matrix: 


L 


Enter the matrix onto the stack. If you are attempting to solve a 
system of linear equations, the matrix should be the augmented 
matrix representation of the system (see discussion above). 
Optional: Set flag —54 if you do not want “tiny” elements replaced 
with zero during the computation: Press ()(MODES) FLAG 54 
=F. “Tiny” elements, which can be generated due to 
roundoff errors during computation, are those elements that are less 
than 1 x 10°! times the size of the largest element in their column. 


Unless you set flag —54, the HP 48 replaces any “tiny” elements 
with zero. 


3. Press (MTH) HATE FACTRE BREF. 


Additional Linear Algebra Topics 


The HP 48 offers a selection of other linear algebra commands that 
give you additional problem-solving power and flexibility. 


Eigenvalues and Eigenvectors 


A square (n x n) matrix A is said to have an eigenvalue \ anda 
corresponding eigenvector x if Ax = Ax. 


Eigenvalues are the roots of the characteristic equation, 

det(A — AI) = 0, which is a polynomial of degree n. Thus, A has n 
eigenvalues, although they are not always distinct. Each eigenvalue 
has a corresponding eigenvector. 


The HP 48 allows you to compute either the eigenvalues only (a 
faster computation) or both the eigenvalues and their corresponding 
eigenvectors. 


To compute the eigenvalues for a square matrix: 


1. Enter the square (n x n) matrix onto the stack. 


2. Press MATE EG‘L to compute a vector of n 


eigenvalues. 
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To compute the eigenvalues and eigenvectors for a square matrix: 


1. Enter the square (n x n) matrix onto the stack. 

2. Press MATE EGY. Ann x n matrix of 
eigenvectors is returned to level 2 and an n-element vector of 
eigenvalues is returned to level 1. The columns of the matrix on 
level 2 represent eigenvectors corresponding to the eigenvalues in 
level 1. 


To decompose or factor a matrix: 


The HP 48 offers a set of matrix decompositions and factorizations 
that you may use either alone or in programmed routines to solve 


LU Crout LU Decomposition. This procedure is used 
in the process of solving an exactly-determined 
system of linear equations, inverting a matrix, and 
computing the determinant of a square matrix. It 
factors the square matrix (A) into a lower-triangular 
matrix L (returned on level 3) an upper-triangular 
matrix U containing ones on its diagonal (returned 
on level 2), and a permutation matrix P (returned to 
level 1) such that PA = LU. 


La LQ Factorization. This procedure factors a mxn 
matrix A into an mxn lower trapezoidal matrix L 
(returned to level 3), an nxn orthogonal matrix Q 
(returned to level 2), and an mxm permutation 
matrix P (returned to level 1) such that PA = LQ. 


GE QR. Factorization. This procedure factors a mxn 
matrix A into an mxm orthogonal matrix Q 
(returned to level 3), an mxn upper trapezoidal 
matrix R (returned to level 2), and an nxn 
permutation matrix P (returned to level 1) such that 


AP = QR. 
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Schur Decomposition. This procedure factors a 
square matrix A into an orthogonal matrix Q 
(returned to level 2) and an upper-triangular matrix 
(or, if A is real-valued, the upper quasi-triangular 
matrix) U (returned to level 1) such that: A = 
QUQT (QT is the transpose of matrix Q). 


SAD Singular Value Decomposition. This procedure 
factors a mxn matrix A into an mxm orthogonal 
matrix U (returned to level 3), a nxn orthogonal 
matrix V (returned to level 2), and a vector S of the 
singular values of A such that: A = US‘V (S‘ is the 
mxn matrix formed by using the elements of S as its 
diagonal elements). 


To compute the singular values of a matrix: 


1 
2 


. Enter the matrix onto the stack. 


. Press HATE FPACTE SWL to return a real vector 


of the singular values, arranged in non-increasing order. 


To reconstruct a matrix from its singular values and orthogonal 
factor matrices: 


1. 
2. Enter the vector S. 

3. 

4. Press HATE DIAG» to construct a matrix using the 


Enter the orthogonal matrix U onto the stack. 
Enter the demensions of the matrix { mn }. 


singular values as its diagonal elements. 


Press (x). 


Enter the orthogonal factor matrix (V) with the same number of 
columns as the original matrix. 


. Press (x) to recompute the original matrix. The degree to which 


the recomputed matrix matches the original matrix reflects the 
accuracy of the decomposition. 


14-22 Matrices and Linear Algebra 


15 


Ses 


inary Arithmetic and Number 


The HP 48 lets you to do binary arithmetic—operations that work 
with binary integers. 


On the HP 48, binary integer objects contain from 1 to 64 bits, 
depending on the current wordsize. You can enter and display binary 
integers in decimal (base 10), hexadecimal (base 16), octal (base 8), or 
binary (base 2). The current base determines which base is used to 
display binary integers on the stack. 


The # delimiter precedes a binary integer. A d, h, o, or b following 
the binary integer indicates its base—for example, # 122d, # B&H, 
# 2660, or # 16116118b. 


To set the current base: 


1. Press (MTH) BASE . 
2. Press one of the following keys: -HE# (hexadecimal), DEC 
(decimal), OCT (octal), or BIH (binary). 
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HEX, DEC, OCT, and BIN are programmable. The settings for flags 
—11 and —12 correspond to the current base. (For more information 

on flags —11 and —12, see appendix D, “System Flags.”) 

The choice of current base has no effect on the internal representation 


of binary integers. 


To view the current base: 


1. Press (MTH) È 


2. View the menu labels; The # in one of the menu labels identifies 
the current base. 


The choice of current base has no effect on the internal representation 
of binary integers. 


To set the wordsize: 

1. Key in a number from 1 to 64. 

2. Press BASE ATHS (the STWS command). (A 
fractional number is rounded to the nearest integer.) 


To recall the current wordsize: 
m Press (MTH) BASE ECHE (the RCWS command). 


To enter a binary integer: 


1. Press G)G). 


2. Enter the value of the binary integer—valid characters depend on 
the base you’re using. 

3. Optional: To specify the base, type a base marker: 4, h, œ, or & 
(Otherwise, the current base is used.) 


4. Press (ENTER). 


Note If a binary integer argument eeeeeds the current 
wordsize, the excess most significant (leading) bits 

a are dropped before the command is executed. If 

necessary, results are also truncated. If a calculation 

produces a remainder, only the integer portion of the 

result is retained. 
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To add or subtract two binary integers: 


1. Enter the binary integer objects. 
2. Press or (-). 


To find the negative of a binary integer: 


1. Enter the binary integer onto the stack. 

2. Press to find the “negative” of a binary number. The negative 
of a binary number is its two’s complement (all bits inverted and 1 
added), since there are no “negative” binary integers in the same 
sense that there are negative real integers. Subtracting a binary 
integer is the same as adding its two’s complement. 


To multiply or divide two binary integers: 


1. Enter the two binary integers. 
2. Press (x) or Œ). Remember that any remainder from a division is 
lost and the answer is truncated to be an integer. 


To convert a binary integer to a different number base: 


1. Enter the binary integer onto the stack. 
2. Press EASE. and press the menu key corresponding to the 
desired number base. 


To convert a binary integer to a real number: 


1. Enter the binary integer onto the stack. It can be in any of the four 
number bases. 

2. Press BASE E+E - to convert the integer to a real 
decimal integer. 


To convert a real number to a binary integer: 


1. Enter the real number onto the stack. 

2. Press BASE E+E to convert the real number to a 
binary integer. If necessary, the real number is rounded first to an 
integer before converting. Negative real numbers are converted to # 
and real numbers > 1.84467440738 x 10!° are converted to the 


a eS SSeS eee eet 


largest binary integer (# FFFFFFFFFFFFFFFFh, for example). 
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Using Boolean Operators 


The following table contains commands from the MTH BASE LOGIC 
menu ((MTH) BASE (NXT) LOGIC) that perform Boolean operations 
on binary integers. Unless otherwise stated, each example assumes the 
wordsize is set to 24. 


, Example | 

Command/Description 9° | 

| Output | 

AND Logical bit-by-bit F | 

AND of two arguments. ii i # | 
NOT Returns the Le i: } 


one’s complement of the | 
argument. Each bit in the 
result is the complement of 
the corresponding bit in the 
ee 


OR Logical bit-by-bit OR jae # LLGGb 
of two arguments. Ls # ilb |i: # Lille 
XOR Logical bit-by-bit 2 # ilib 
exclusive OR. of two i # ilib |i # 11Gb 


| arguments. | 


Manipulating Bits and Bytes 


The following table contains commands from the MTH BASE BIT 
and MTH BASE BYTE menus (MTH) EASE BIT and... 
ETE ) that are useful for manipulating binary integers either one 
bit or one byte at a time. Unless otherwise stated, each example 

assumes the wordsize is set to 24. 
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Command / Description 


Example 


Output 


ASR Arithmetic Shift 
Right. Performs 1 bit 
arithmetic right shift. The 
most significant bit is 
regenerated. 


bet | 


RL Rotate Left. Binary 
integer rotates left one 
bit. (Example assumes 
wordsize=4.) 


RLB Rotate Left Byte. 
Binary integer rotates left 
one byte. 


pers 


RR Rotate Right. Binary 
integer rotates right one 
bit. (Example assumes 
wordsize=4.) 


RRB Rotate Right Byte. 
Binary integer rotates right 
one byte. 


SL Shift Left. Binary 
integer shifts left one bit. 


# 1i8ib 


SLB Shift Left Byte. 
Binary integer shifts left one 
byte. 


| 

| 
4 ABBACGH = 

| 

| 

| 


SR Shift Right. Binary 


one byte. 


# 1iðiik i # 1i5ik 
integer shifts right one bit. 
SRB Shift Right Byte. H REBALAR 4 # ABBE 


Binary integer shifts right 
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Date, Time and Fraction Arithmetic 


The HP 48 has a sophisticated built-in clock and calendar. The HP 48 
uses the Gregorian calendar which reformed the Julian calendar on 
October 15, 1582 CE. Dates prior to that (or after December 31, 9999) 
are not valid. 


Calculating with Dates 


The TIME command menu contains special commands that allow you 
to calculate calendar and clock intervals. 


The following table illustrates the time and date formats available on 
the HP 48. The time and date illustrated is 4:31 PM on February 21, 
1992. 


Clock Display Format Number Form 
Date: 
Month/day/year format 


Day.month.year format 


12-hour format 16,31 
24-hour format 16, 5184 


To set or change the current date format: 


. Press (@)(TIME) (A) GE 
. Press ()(®) to highlight the date format field. 
. Press until the desired date format is displayed 


. Press OHE- to confirm the selection. 


A GO ND be 
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To put the current date on the stack (in number form): 
a Press ()(TIME) DATE. 


To add or subtract a given number of days from a given date: 


1. Enter a date in the number form corresponding to the current date 
format. 

2. Enter a real number representing the numbers of days you want to 
add or subtract. Use negative numbers if you want to subtract 
days. 

3. Press (4)(TIME) GATE+. The adjusted date is returned in 


the number form of the current date format. 


Example: Find the date 239 days from today. (This example 
assumes the current date is April 30, 1993.) 


Step 1: Put the current date in level 1. 


(TIME) PATE 1: 4.361993 
© TICES 


Step 2: Enter the number of days and calculate the future date. The 
result is December 25, 1993. 


239 CATES l: 12.231993 


JOA TE*/ 00H S| +H [HbA + [HME + a] 


To determine the number of days between two dates: 


1. Enter the first date number onto the stack. 
2. Enter the second date number onto the stack. 


3. Press (4)(TIME) GEAT. 


Example: Find the number of days between April 20, 1982 and 
August 2, 1986. 


4.201982 8.021986 
CDCME DAYS 


1: 1565 
[DATE ES Ed Cd Cee ee 
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Calculating with Times 


To set or change the current time format: 


1. Press (œ) ŒM) (A). -GE 

2. Press œ) >) Œ) to highlight the time format field. 

3. Press (*+/-) one or more times until the desired format is displayed. 
4. Press to confirm your choice. 


To put the current time on the stack (in number form): 


A number with HMS (hours-minutes-seconds) format is represented as 


H.MMSSs: 


H Zero or more digits representing the number of hours. 

MM Two digits representing the number of minutes. 

SS Two digits representing the number of seconds. 

s Zero or more digits representing the decimal fraction part of 
seconds. 


To convert a time number from decimal hours to HMS format: 
1. Enter the time number in decimal form. 

2. Press (€)(TIME) (NXT) #HNS . 

To convert a time number from HMS format to decimal hours: 


1. Enter the time number in HMS form. 


2. Press ()(TIME) (NXT) HHS. 
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To add two time numbers in HMS format: 


1. Enter the two time numbers in HMS format. 


2. Press (44)(TIME) HMS+ . The time number returned is also 
in HMS format. 


To subtract two time numbers in HMS format: 


1. Enter the two time numbers in HMS format. 


2. Press ()(TIME HMS~ . The time number returned is also 
in HMS format. 


To convert a time and date into a text string: 


1. Enter the date number onto the stack. 

2. Enter the time number. 

3. Press (H) (IME) (NXT) (NXT) TESTE. A text string will be 
returned showing the day of the week, the date (in current date 
format) and the time (in the current time format). 


To put the system time on the stack: 


1. Press (A) (TIME) TICES. System time is kept in “ticks” of the 
clock. Each tick is 1/8192 of a second in duration. The total 
number of ticks is reported as a binary integer. TICKS is useful for 
measuring elapsed time, and can be converted into a standard time 
number in either decimal or HMS format. 


To convert a system time (ticks) into HMS format: 


1. Enter the eyatem time. It should be a binary number. 

2. Press (MTH) BASI E+E to convert the system time to a real 
number. 

Press 29491200 (+) to convert to decimal hours. 

4. Press (|) (ME) *HME. to convert decimal hours to HMS 


format. 


aw 


To calculate elapsed time in seconds: 
Press ()(IIME) TICES to start timing. 


Press TICES to stop timing. 

Press (SWAP) ©) to er the elapsed time in clock ticks. 

Press E E+E 8192 G) to calculate the elapsed time 
in seconds. 
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Calculating with Fractions 


A fraction is an algebraic representation of an arithmetic operation 
that hasn’t yet been evaluated. For example, the fraction 4 is a 
means of representing the result of a division operation 4 + 3 without 
actually dividing. The mixed fraction 43 represents the algebraic 
operation 4 + (5 + 6). The HP 48 uses these algebraic representations 


to display fractions: 


To enter a fraction: 


a Using the Equation Writer: 
1. Press ()(EQUATION). 
2. Type in the fraction. Press (A) to begin a numerator and (F) (or 
(®)) to move from the numerator to the denominator. 
3. Press 
a Using the command line: 
1. Press (1) (because the fraction is an algebraic). 
2. Type in the fraction onto the command line. 


3. Press (ENTER). 


To add, subtract, multiply, and divide with fractions: 


1. Enter the fractions onto the stack in the same order as you would if 
they were decimal numbers. 


2. Execute the operation (Œ), ©, (x), or ©). 
. Press (EVAL) to convert the expression into a decimal answer. 


w 


To convert a decimal into a fraction: 


1. Put the decimal on level 1 of the stack. 

2. If necessary, change the display mode. The accuracy of the 
fractional approximation is dependent on the display mode. If the 
display mode is Sic, the approximation is accurate to 11 significant 
digits. If the display mode is n Fix, the approximation is accurate 
to n significant digits. 


3. Press ()(GYMBOLIC) (NXT) +ù 
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To convert a fraction into a decimal: 


m Put the fraction on level 1 of the stack. 
m Press (EVAL). 


To convert a decimal into a fraction involving z: 


1. Put the decimal on level 1 of the stack. 

2. If necessary change the display mode to indicate the accuracy of 
the fractional approximation you desire. 

3. Press (4,)(SYMBOLIC) (NXT) +8 . —Qr computes both the 
fractional equivalent of the original number and the fractional 
equivalent of the original number divided by 7, and then compares 
the denominators. It returns the fraction with the smallest 
denominator—this fraction might be the same fraction returned by 
—Q, or it might be a different fraction multiplied by 7. 


Example: Convert 7.896 to a pure fraction using >Q. 


7.896 (SYMBOLIC) (NXT} 1: ‘967-125! 
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Lists and Sequences 


Creating Lists 


To enter a list from the keyboard: 

1. Use (|) to indicate the beginning and end of a list. 

2. Enter the elements of the list. Use to separate each element. 
To assemble a series of elements into a list: 


1. Enter the elements on the stack. 
2. Enter the number of elements on the first level of the stack. 
3. Use LEST LITST to convert the stack elements to a list. 


Example: Create a list with the following elements 7 11 13 using 


Sib Se. 
Step 1: Enter the elements and number of elements on the stack. 


7 ENTER) 11 ENTER) 13 
(ENTER) 3 (ENTER) 


1 
1 
WECTRLMATR] List | HYP [REAL | BASE | 


Step 2: Convert the stack to a list. 


LIST LIST 1: i r 11 133 
[ELEH | PROC [OE [$LIST] SUE [REPL] 


To append a new element to the beginning of a list: 


1. Enter the new element. 
2. Enter the list. 


3. Press $). 
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To append a new element to the end of a list: 


1. Enter the list. 
2. Enter the new element. 


3. Press (4). 


The way the calculator performs operations on lists is called list 
processing. 


To apply a one-argument command to each element in a list: 


1. Enter a list. 
2. Execute the command. 


Example: Find the factorial of 3, 4, and 5. 


Step 1: Enter the numbers in a list. 


3 4 5 l: 13457 

GPs) 4 GPC) PELEM] PROC [Ded [$LisT] Sue [REPL | 
Step 2: Find the factorials of the elements. 

(MTH) (NXT) FROE l: { 6 24 124 } 

PCOME/ PERM]! [kanp] Rin f | 


To perform a two-argument command using a list and a number: 


1. Enter the list. 
2. Enter the number. 
3. Execute the command. 


Note that you must use LIST ADD instead of to add a 


number to each element of a list. 


Example: How many combinations can be made from 4 objects 
taken 3 at a time? How about 5 objects? And 6 objects? 
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Step 1: Enter a list that contains the objects, and enter the number 
of objects taken at a time on level 1. 


D 4 GPO) 5 GPC) 6 2: ERTI 


ENTER) 3 (ENTER l: ; 
(ENTER) (ENTER) (COME[ PERM] =! [RAND] kiz | | 


Step 2: Find the number of combinations. 


aa j: {419 283 
coMe|PERM| [RAND] Roz [| 


Multiple-Argument Commands with Lists 

Operations that operate on two objects can also operate on individual 
corresponding elements of two lists. 

To add corresponding elements of two lists: 


1. Enter both lists. 
2. Execute the ADD command. 


Example: Add {321} and {456 }. 
Step 1: Enter the two lists. 


om e - Pare 
(ENTER) 3) 4 (SPC) 5 (SPC) {LF 
6 ENTER) come [Perm] [RAND] koz | 


Step 2: Add the corresponding elements of the lists. 


MTH l: {rrrt 
[DEJ> | SORT PREVLIPTLISTIELIST] ADD | 


To concatenate two lists: 


1. Enter the list whose elements will form the first part of the 
concatenated list. 

2. Enter the list whose elements will form the latter part of the 
concatenated list. 


3. Press (+). 
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Example: Concatenate { 3 2 1 } and { 45 6 }. 


Step 1: Enter the two lists. 


(DGH 3 (SPC) 2 GPC) 1 T ' A E : 
(ENTER) (DC 4 GPC) 5 GPC) : 
6 (ENTER ECTREMATR] List | HYP | REAL | BASE | 


Step 2: Concatenate the lists. 


1: C32 a A, 
hECTALMATRT ETT AE TRE 


To subtract, multiply, or divide corresponding elements of two lists: 


1. Enter both lists. 
2. Execute the operation. 


Applying a Function or Program to a List (DOLIST) 


You can run programs or execute functions on groups of lists. 


To run a program or execute functions on lists: 


1. Enter the lists. 

2, Enter the number of lists operated on. This number is actually the 
number of elements operated on with each iteration of the function 
or program. 

3. Enter a program or function. 

4. Execute DOLIST. 


Example: Create 3 lists (a, b, and c) and execute a function that 
does the following to each element an + (bn X cn). 


Step 1: Enter the lists and the number of lists to be operated on (3). 


AO | GO? E3 
(ENTER) (4) (43) 4 (SPC) 5 (SPC) 
6 (ENTER) (DCJ) 7 (SPC) 8 
(SPC) 9 (ENTER) 3 (ENTER) 
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Step 2: Enter the function and execute it. 


SC) &) G) ENTER) PRS) L: { 29 ¢42 5 os 
CISTO PROC DOLTS [ontis [DOZUE]MSUE LENDS |S TRE) EYL 


To apply a procedure sequentially to elements of a list: 


1. Enter the list. 

2. Enter the frame index. This is the number of elements affected by 
each iteration of the function. For example, entering 3 would take 3 
elements from the list and use them as arguments for the function. 

3. Enter the function. 

4. Execute £ E. 


Example: Find the 2-element moving average of {12345}. 


Step 1: Enter the list, the frame index, and the function. 


CDE 1 GPO) 2 GP) 3 (SPC) 
4 (SPC) 5 (ENTER) 2 (ENTER) 
QO O20 GE) 


Step 2: Execute DOS 


GEST “Pen 


l: £ 1.5 2.5 3.5 4.9 2) 
[OLIE [00SUeTNSUE [ENDS |ETAEA[ REVLI] 


When writing programs with DOSUB the frame number (the position 
of the first object in the frame) is NSUB, and the number of frames is 
ENDSUB. 


Applying a Function Recursively to a List 

The STREAM command lets you apply a function recursively to every 
element of a list. 

To execute a function on every element of a list: 


1. Enter the list. 
2. Enter a program or function. A program or function that takes two 
arguments and returns one result is ideal. 
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m LIST 


3. Execute STREAM. STREAM is designed to take the first two 
elements, excute the operation, then take the result and the next 
element and execute again. This process continues until all the 
elements have been used as arguments. 


Example: Multiply all of the elements in { 1 2 3 4 5 } together. 


Step 1: Enter the list and the function. 


OC | GPC) 2 GPO 3 GPO e: {1234523 
2 «<>» : pele 
Co EEN I) | Aiea mera mowers 


Step 2: Execute the function. 


LIST STREA l: ict 
(POLIZ [OOSUB]NSUE [ENDS [STREA|REVLI| 


List Manipulations 


The following functions provide ways to manipulate the elements of a 
list: 


m (MTH) LEST SORT sorts the elements of a list in ascending 
order. The list must be on level 1. 


m (MTH) LITST LT reverses the elements of a list. The list must 


be on level 1. 


m adds items to the begining or end of a list, or concatenates two 
lists. To add an item to begining of a list, enter the item, enter the 
list, and then press (). To add an item to the end of a list, enter 
the list, enter the item, and then press G). 


NXT replaces the list on level 1 with 


the list’s first ekaine 


replaces the list on level 1 with 


f: O GET replaces the list on level 2 and 
position index on level 1 with the element at that position within 
the list. 
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PRG) EÈ LEM GETI similar to GET, but it also increments 
a position index. “The new index is put on level 2. The original list 
is put on level 3. 

LIST FUT takes an object from level 1 and 
replaces an existing object within a list. You must supply a position 
index on level 2, and a list on level 3. The resulting list is on level 

1. 

PRG EHTI similar to PUT, but it also increments 
a position dee The new index is put on level 1. The new list is on 
level 2. 

LIST E- replaces the list on level 1 with the 
ae of Slementa in the list. 

| | FS replaces a list on level 2 and an 
element ori that list on level 1 with a position index for the 

first occurrence of that element. If the element is not found, 0 is 
returned, 

LIST OB puts each object from a list on level 1 onto 

the stack, plus puts the number of objects in level 1 
(PRG) LT! SUE returns a list of elements from the list on 
level 3 o : the starting and ending positions in levels 2 and 
1. 

(PRG) |. replaces elements of a list on level 3 with 


clement: pe a list on level 1 starting at the element specified in 
level 2. 


Sequences 


Sequence commands automate the generation of a list from the 
repeated execution of a function or program. 


To generate a sequence: 


1. Enter the function or program (or its name). 
2. Enter the index variable name. 
4 


. Enter the final value for the variable. 


Enter the initial value for the variable. 
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5. Enter the step size of the increment. The number of elements 
generated is the integer portion of (finial) +1. 
6. Execute SEQ 
Example: Generate a list of squares from 23 to 27. 
Step 1: Enter the function, the variable name, the initial value, and 
the final value. 


OA @) X (ENTER) CD 
(a) X (ENTER) 23 (ENTER) 27 rope 
Mt 
53 
poui OUSUETNSUE Tents [STRERP RET 


Step 2: Enter the step size, and generate the sequence. 


1 ENTER) PRG) LIST 1: Lae 376 625 676 
BREE oo emr e O Tut 


To find the sum of a finite sequence expressed as a list: 

1. Enter the list. 

2. Execute (MTH) LIST ELTST. 

You can also find the sum of a finite sequence using the E function in 
an algebraic expression—see page 7-5. 

To find the product of a finite sequence expressed as a list: 

1. Enter the list. 

2. Press ETSE TEIST. 

To find the set of first differences of a finite sequence: 


1. Enter the sequence as a list. 

2. Press LIST ALIST. 

The first differences for the list £ z4 vo... £n 7 is defined as 
È Tat]... In-ly_1 $ 
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Solving Equations 


Solving an Equation for an Unknown Variable 


To solve an equation for numeric answers by hand, you might use the 
following general procedure: 


1. Write down the equation you want to solve. 


2. If possible, manipulate the equation to solve for the unknown 
variable. 


3. Substitute known values for the given variables. 
4. Calculate the value of the unknown variable. 


When you use the SOLVE application, you follow a similar 
procedure—exrcept you don’t need to do step 2, and that simplifies the 
process. 


To solve an equation for an unknown variable: 


1. Press (@)GOLVE) 0E 

2. Enter or choose the equation you wish to solve. 

3. Enter values for all of the known variables. 

4. Optional: Enter a guess value for the unknown variable. This can 
make the search quicker or guide the root-finder to a particular one 
of several possible roots for a given equation. 

5. Move the highlight to the unknown variable and press BULVE 


The SOLVE application can solve for the numeric value of a variable 

in an equation, expression, or program: 

a Equation. An equation is an algebraic object containing = (for 
example, 'A+E=t'). A solution is a value of the unknown variable 
that causes both sides to have the same numeric value. 


(for example, 'A+E+C'). A solution is a root of the expression—a 
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value of the unknown variable for which the expression has a value 
of 0. 


a Program. A program to be solved must return one real number. A 
solution is a value of the unknown variable for which the program 
returns 0. 


To enter a new equation to solve: 


1. Open the SOLVE application, if necessary, by pressing (->) (SOLVE). 
There may or may not already be an equation entered into the 
form. 


ENTER FUNCTION TO SOLVE 
petit [chons] [vars | 


2. Make sure the highlight is located in the Ett field and do one of 
the following: 
m Type the equation, expression, or program (with proper 
delimiters) into the command line and press (ENTER). 
m Press ()(EQUATION), then type in the equation or expression in 
the EquationWriter, and then press (ENTER). 


To select a previously-created equation to solve: 


1. Open the SOLVE application, if necessary, by pressing (@®)(SOLVE). 
2. Make sure the highlight is located in the EG: field and press 


3. Use the arrow keys to find the desired variable. If it isn’t in the 
current directory, press HOZ again, select the proper directory, 
and press = GE... Then find the desired variable and press 

GE once more to enter the variable into the Ef: field. 


Whenever an equation is entered into the Em: field, there will also 
be variable names displayed as well. There will be a label for each 
variable in the current equation, except if a variable contains an 
algebraic object, in which case labels are included for the variables i in 
the algebraic itself. For example, if the current equation is ' aoe 
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and B contains the expression `È 


D, E, and C. 


+. you will see labels for A, 


For equations that use a placeholder variable— 
such as an integral, summation, or derivative, the 
placeholder variable will have a label displayed. 
However, you will not be able to solve for a 
placeholder variable. 


Note 


If one or more of the variables does not already exist, it will be created 
and added to the current directory when you solve the equation the 
first time. 


To enter a value for a known variable: 


1. Move the highlight to the field labeled with the name of the known 
variable. 


2. Type in the value and press (ENTER). 


To store an estimated value for an unknown variable: 


1. Move the highlight to the field labeled with the name of the 
unknown variable. 


2. Type in the guess value and press (ENTER). 


To solve for an unknown variable: 


1. Move the highlight to the field labeled with the name of the 
unknown variable. 

2. Press SOLE. The result will be displayed in the field and a 
labeled copy put on the stack. 


Interpreting Results 


The SOLVE application returns a message describing the result of the 
root-finding process. You can use this message and other information 
to judge whether the result is a root of your equation. 


To interpret the computed result: 


a After the result has been computed, press 
to clear it when you've finished viewing it. 
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The message is based on the value of the equation—the difference 
between the left and right sides of an equation, or the value returned 
by an expression or program. 


If a root is found, the SOLVE application returns a message describing 
the root: 


The SOLVE application found a point where the 
value of the equation is 0 within the calculator’s 

12-digit precision. 

The SOLVE application found two points where 

the value of the equation has opposite signs, but 

it cannot find a point in between where the value 
is 0. This may be because: 


a The two points are neighbors (they differ by 1 
in the 12th digit). 

m The equation is not real-valued between the 
two points. The SOLVE application returns 
the point where the value is closer to 0. If 
the value of the equation is a continuous real 
function, this point is the SOLVE application’s 
best approximation of an actual root. 


EX. Mm epim One of the following occurred: 


m The SOLVE application found a point where 
the value of the equation approximates a local 
minimum (for positive values) or maximum (for 
negative values). The point may or may not 
represent a root. 

a The SOLVE application stopped searching at 
+9.99999999999E499, the largest or smallest 


numbers in the calculator’s range of numbers. 


To obtain more information about the solution: 


m Do any or all of the following: 


= (ENTER). For 
an expression or program, the closer the result (labeled Expr) is 
to 0, or for an equation, the closer the two results (labeled Lat ti 
i ?) are to each other, the more likely it is that the 
SOLVE application found a root. You must use judgement in 
considering the results. 
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a Plot the expression or equation in the region of the answer. The 
PLOT application will show any local minimum, maximum, or 
discontinuity. 

a Check the system flags that detect mathematical errors (see 
appendix B for a list of such errors). For example, flag —25 
indicates whether overflow occurred. 


If the SOLVE application can’t return a result, it displays a message 
indicating the reason: 


One or more of the initial guesses lie outside 

the domain of the equation—or units for the 
unknown variable aren’t consistent with the units 
for the other variables. Therefore, when the 
equation was evaluated, it didn’t return a real 
number or it generated an error. 


Constant t The value of the equation is the same value at 
every point sampled. 


Solving Options 


To display the root-finder at work: 


1. Immediately after pressing SOLE to begin the root-finder, press 
(ENTER). You will see two intermediate guesses and the sign of the 
expression evaluated at each guess (displayed to the left of each 
guess). 


Watching the intermediate guesses can give you information about 
the root-finder’s progress—whether the root-finder has found a sign 
reversal (the guesses have opposite signs), or if it is converging on a 
local minimum or maximum (the guesses have the same signs), or if 
it is not converging at all. In the latter case, you may want to halt 
the root-finder and restart with a new guess. 


To halt and restart the root-finder: 
1. While the root-finder is working, press (CANCEL). The root-finder 


halts and displays current guess in the unknown variable’s field. 
2. To restart the root-finder, do one of the following: 
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mw Press SOLE to restart from where it left off. 
w Enter a guess into the unknown variable’s field and press 
to restart the root-finder searching in a different region. 


To use units while solving for an unknown variable: 


1. To store a value with units in a variable, enter the unit object. into 
the desired variable field. Note that all variables must contain a 
consistent set of units——including ae unknown variable—before 
solving (or else you will generate a Bac & z 

2. To change a variable’s value and ka its alk units, enter the 
number only. 

3. To return a solution with units attached, enter a guess for the 


unknown variable that includes the desired units, before pressing 


To rearrange the order in which the variables appear: 


1. From the main SOLVE EQUATION screen, press SARS and do one 
of the following: 
m Press EDIT , edit the variable list into the order that you want, 
and press (ENTER). 
m Press (4)((3), type the variables in the order you wish them to 
appear, and press (ENTER). 
2. Press HE to record the changes and return to the main SOLVE 
screen, You will see the variables in their new order. 


SOLVR: An Alternative Solving Environment 


There is an alternative solving environment available on the HP 48G 
Series calculators that works like the solving environment on their 
predecessors, the HP 48S and HP 48SX. This environment, SOLVR, 
makes use of the same built-in root-finder as the SOLVE application, 
but allows you to continue to see and use the stack while you are “in” 
the environment. 


While the approach to solving equations is similar for both solving 
environments, the procedures used are somewhat different. 
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To enter the equation to be solved: 


1. Put the equation (or properly-designed program) on stack level 1. 
You may type it in using the command line or the Equation Writer 
or recall it from a variable. 

2. Press (4,)(SOLVE) 4 ; 

3. Press (4) -E (or type STEG and press (ENTER)) to make the 


equation on level 1 the current equation. 


To enter the SOLVR root-finding environment: 
m Press (4)(SOLVE) ROOT. SOLVE to enter the SOLVR 


environment. You will see the variables in the current equation 
displayed as white menu labels in the bottom row of the display and 
the current equation (stored in Ef!) displayed in the top row. For 
example: 


To enter values for known variables using SOLVR: 


1. If necessary, enter the SOLVR environment. 
2. Type in the value of the known variable and press the menu key 
corresponding to the variable’s white menu label. 


To recall the value of a known variable: 

a Press (>) and then the menu key corresponding to the variable’s 
white menu label. 

To solve for an unknown variable in the SOLVR: 


1. Make sure that all known variables have values stored in them. 

2. Optional: Enter a guess estimate for the value of the unknown 
variable by typing in the guess and pressing the unknown variable’s 
white menu key. 


Solving Equations 18-7 


18 


18 


Press (4) and then the unknown variable’s white menu key. The 
labeled result will be returned to stack level 1 and a message 
interpreting the result is displayed at the top of the screen. 


. Optional: Press EXF R= to evaluate the current equation using the 


newly computed value for the unknown variable. See “Interpreting 
Results” on page 18-3 for more details about intrepreting the 
results of the root-finder. 


Additional Solving Options in SOLVR 


In addition to providing a different environment for finding roots of 
equations, expressions and programs, SOLVR allows you a few options 
not available in the SOLVE application. 


To sequentially solve a series of equations using SOLVR: 


1. 


Ww 


. Press 


Enter the equations that you want to use onto the stack in the 
order that you will probably want to solve them. Begin with 

the equation containing only one unknown variable. The other 
equations may begin with additional unknown variables, although 
they should have only one variable that remains unknown after 
each of the equations preceeding it have been solved. 


. Press (A) repeatedly until the stack pointer indicates the first 


equation to be solved. 
Press #LIS7 to gather the equations into a list. 
Press (4)(SOLVE) FOOT (4) ER to store the list into EG as 
the current “equation.” 
Enter the SOLVR environment, enter values into the known 
variables, and solve for the unknown variable in the first equation 
as you would if there were only one equation. 

Me (you may need to press one or more times 
if there are many variables) to make the “next” equation in the 
list into the current equation. The equations are actually rotated 
within the list, so that the first equation is now the last, the second 
equation now the first, the third now the second, and so forth. 
Enter any additional known values and solve for the remaining 
unknown variable in the equation. 
Repeat steps 6 and 7 until you have solved for all of the unknown 
variables in the series of equations. 


You may prefer to use the Multiple Equation Solver instead of SOLVR 
for this kind of task (see page 25-6). 
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To create a customized SOLVR menu: 


1. Enter a solver-list in level 1 of the stack. The syntax of a solver-list 
is Z equation = key-definitions 3 +, where: 
equation Specifies the equation. It can be an equation or 
expression (with ' delimiters), a program object 
(with £ delimiters), or the name of an equation, 
expression, or program. 
key-definitions Specifies the menu keys—each entry defines one 
key. Each entry can be either a variable name 
or other type of object. Variable names will be 
displayed with white menu labels, other objects 
will be displayed with black menu labels. To 
include a program that you can execute, enter its 
name in the key-definition as a sublist of the form 
© "label" € name® >. 
2. Press (4)(SOLVE) ROOT (e) E& to make the equation in the 
solver-list the current equation and display the custom SOLVR 


menu according to the key definitions. 18 


Example: The equation J = 27° f? pva? calculates the intensity of a 
sound wave. Suppose you always calculate the value of p 
and store it in the corresponding variable prior to using 
this equation, and so would like to suppress p from the 
SOLVR menu. Furthermore, suppose you want the IP 
command available in the SOLVR menu so that you can 
store integer values in the variables in the SOLVR menu. 
The following solver-list list includes two additional keys: 
a blank key and a key that executes IP (integer part) and 


suppresses p. 


The list, when stored in EQ, creates this menu of variables and 
functions: 
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Finding All Roots of a Polynomial 


A symbolic polynomial, such as z3 + 4x? — Tg + 9, can also be 
expressed as a vector of its coefficients: [1 4 —7 9 ]. In this vector 
form, very efficient numeric techniques can be applied to find a vector 
of its roots. 


To use the polynomial root-finder: 


w Press (>)GOLVE) (VY) M) GE to display the following: 


SERRE SOLVE AMN H+ tAl-4+A0 SEE 
COEFFICIENTS [ AN w Al AO F 


ROOTS: 


ENTER COEFFICIENTS OR PRESS SOLVE 
EMT =f SE [EDLYE| 


To find all roots of a polynomial: 


1. Open the polynomial root-finder. 

2. Move the highlight to the COEFFICIENTS field, if necessary. 

3. Enter the polynomial in coefficient form. Use either the command 
line (don’t forget the E 2 delimiters)or the MatrixWriter. Note 
that the first element in the vector should be the coefficient of the 
highest order term and the last element should be the constant 
term. Remember to include zeroes wherever “missing” terms are 
located in the polynomial. 

4. With the highlight located in the EO 
complex array of roots is displayed in th 
labeled copy sent to the stack. 


field, press SOLVE. A 
Se field and 


To find a polynomial, given a set of roots: 


1. Open the polynomial root-finder. 

2. Move the highlight to the ROOTS: field, if necessary. 

3. Enter the set of roots as a vector. Remember that if any of the 
roots are complex, then you must enter all roots as complex (real 
roots are entered as ¢ real; & 7); 

4. Move the highlight to the COEFFI 


EHTS field and press SULVE. 
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To evaluate a polynomial at a given value: 


1. Enter the polynomial in coefficient form onto the stack. 
2. Enter the given value at which you want to evaluate the 
polynomial. 


3. Press (;)(SOLVE) F 


To convert a polynomial from coefficient to algebraic form: 


1. Open the polynomial root-finder. 

2. If it doesn’t already contain the poly nomial in coefficient form, 
enter it into the £ 

3. With the highlight on the field, press 
The symbolic polynomial is sent to othe stack using * as the 


variable. 


Solving a System of Linear Equations: 


The HP 48 can solve a system of linear equations. To create your 
system of equations, you can either choose them from among those 
you've stored, or enter them directly. 


As you solve a system of equations, remember that a system of 
equations can be represented by a single matrix equation of the form 


A-X = B: 


Equation Form Matrix Form 
ar + by +c: =k a b c x ky 
dr + ey — fz = kə = d e -f}l Jy] = [ke 
gr + hy + iz = k3 g h i Zz k3 


The HP 48 makes use of this representation to solve systems of linear 
equations rapidly and efficiently. 


To solve a system of linear equations: 


1. Press (@)(GOLVE) (4) (A) GE to begin the Linear System 
Solver. 
2. Enter the matrix of coefficients in the fF: field. You can use either 


the MatrixWriter or the command line. 
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3. Enter the array of constants in the B: field. 

4. Move the highlight (if necessary) to the ## field and press + . 
The result array (with the same draniona as the constants array, 
E) is displayed in the #: field and a labeled copy placed on the 
stack. 

5. Optional: Press -E 


to view the result in the MatrixWriter. 


The Linear System Solver will return a result array for any of the 
following systems: 


m Exactly-Determined Systems. The number of equations equals the 
number of independent variables in the system. The result returned 
will be exact (to within the limits of precision of the HP 48), as long 
as the coefficient matrix is not ill-conditioned (see “Il-Conditioned 
and Singular Matrices” on page 14-16). 

a Over-Determined Systems. The number of equations is greater than 
the number of variables in the system. There is usually no exact 
solution to over-determined systems so the least-squares solution is 
returned. 

m Under-Determined Systems. The number of equations is smaller 
than the number of independent variables in the system. There are 
usually an infinite number of solutions to under-determined systems 
so the one with the minimum Euclidean norm is returned. 


Be sure to pay attention to the nature of the linear system you are 
solving because it will influence how you should interpret the result 
array. In some cases, you will want to test for ill-conditioning (see 
page 14-16) before accepting even an exact solution as a “true” 
solution. 


Another approach to testing the validity of an answer is to find the 


residual of the solution (A-X — B). Accurate solutions have residuals 
close to zero. 


To find the residual (4-Y — B} of a solution: 


1. Make sure the computed solution array is on stack level 1, and 
press to duplicate it. 

2. Enter the constants array (B) on the stack. 

Enter the matrix of coefficients (A). 

4. oo (4) (STACK) r to move the solution array back to level 


eee (D (SOLVE) ye 


solution. 


ow 


ESE to compute the residual of the 


ont 


18-12 Solving Equations 


See 14-17 for additional approaches to testing the accuracy of a 
computed array solution. 


Using the Finance Solver 


The Finance Solver application provides time-value-of-money (TVM) 
and amortization capabilities. You can use it for compound-interest 
and amortization calculations. 


Compound interest occurs when earned interest is added to the 
principal at specified compounding periods, and then the combined 
amount earns interest. Many financial calculations are compound 
interest calculations—for example, savings accounts, mortgages, 
pension funds, leases, and annuities. 


Time Value of Money calculations, as the name implies make use the 
notion that “time is money.”——that a dollar now is worth more than a 
dollar at some time in the future. A dollar now can be invested and 
generate a return that the dollar-in-the-future cannot. This TVM 
principle underlies the notion of interest rates, compound interest and 
rates of return. 


TVM transactions can be represented and understood by using cash 
flow diagrams. A cash flow diagram is a time line divided into equal 
segments representing the compounding periods. Arrows represent. the 
cash flows. Money received is a positive value, and money paid out is 
a negative value. 


The cash flow diagram for a transaction depends on the point of view 
you take in your problem statement. For example, a loan is an initial 
positive cash flow for the borrower, but it’s an initial negative cash 
flow for the lender. 
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The following cash flow diagram shows a loan from a borrower's point 


of view. 


Present value (PV) 


(Loan) 
Money 
evel Equal periods 
positive |< uae ng mE 
number | 4 y 9 y 3 v 4 y 5 
Payment Payment Payment Payment (PMT) 
Money (PMT) (PMT) (PMT) (PMT) 
paid out is , 
a negative 
Amber Equal payments 


Future value 


FV) 


The following cash flow diagram shows a loan from a lender’s point of 


view. 


Equal payments 


Loan 


Equal periods 


In addition, cash flow diagrams specify when payments occur relative 
to the compounding periods: at the beginning of each period or at the 
end. The Finance Solver application provides both of these payment 
modes: Begin mode and End mode. 
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The following cash flow diagram shows lease payments at the 
beginning of each period. 


PV 


| Capitalized 
au of 
| lease 


viv2vayvé ys 


PMT PMT PMT PMT PMT 


The following cash flow diagram shows deposits into an account at the 
end of each period. 18 


As the foregoing cash-flow diagrams imply, there are five TVM 
variables: 


H The total number of compounding periods or 
payments. 

The nominal annual interest rate (or investment 
rate). This rate is divided by the number of 
payments per year (FYE) to compute the nominal 
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interest rate per compounding period—which is the 
interest rate actually used in TVM calculations. 

PY The present value of the initial cash flow. To a 

lender or borrower, PV is the amount of the loan; to 

an investor, PV is the initial investment. PV always 
occurs at the beginning of the first period. 

The periodic payment amount. The payments 

are the same amount each period and the TVM 

calculation assumes that no payments are skipped. 

Payments can occur at the beginning or the end of 

each compounding period—an option you control by 

setting the Payment mode to Bes or End. 

Fis The future value of the transaction: the amount of 
the final cash flow or the compounded value of the 
series of previous cash flows. For a loan, this is the 
size of the final balloon payment (beyond any regular 
payment due). For an investment this is the cash 
value of an investment at the end of the investment 
period. 


To perform a TVM calculation: 
1. Press (@)GOLVE) (A) GE. to begin the Finance Solver 


application. 


: TIME VALUE OF MONEY % 
EO EEE G 

pe, BO 

PMT: 8, 8B Peyk: 12 


FE 8, BG End 


ENTER MO. OF PAYMENTS OR SOLVE 
epit | ff fate fe oye} 


The Finance Solver 


2. Move the highlight to a field labeled as a TVM variable, type the 
appropriate value and press (ENTER). Be sure that values are 
entered for at least four of the five TVM variables. 

3. If necessary, enter a different value for PeR., 

4. If necessary, press to change the Payment mode (Be or Emel) 
as required. 

5. Move the highlight to the TVM variable you wish to solve for and 
press SELVE. 
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Example: Otto Tailfin is financing the purchase of a car with 
a 3-year loan at 10.5% annual interest, compounded 
monthly. The purchase price of the car is $11,250, and his 
down payment is $2500. What are his monthly payments? 
What is the largest loan Otto can afford if his maximum 
monthly payment is $225? (Assume that payments start 
at the end of the first period.) 


PV=11,250-2,500 


I%YR = 10.5 


N=3-x 12 


PYR = 12; End mode 


ivy2y vs yy 


PMT=? 


Step 1: Open the Finance Solver, and make sure there are 12 
payments/year (monthly payments) and that payments are 
made at the end of each compounding period. 


OEDD ok 
SOE Geak 
necessary) 


ZE TIME VALUE OF MONEY % 

N B YR: By 

PY: B., Be 

PMT: 4, BG PeR: 12 


FY 0. BG 


CHOOSE WHEN PAYMENTS ARE MADE 
EE Le f o [arnR] 


Step 2: Enter the known TVM variables. Make sure to set the FV 
to 0 because the loan is fully paid after 3 years (3 x 12 
payments). 


CS 3 10.5 


2500) | 


E 11250 ENTER) 


(NXT) (¥) (¥) 0 


TIME VALUE OF MONEY $ 
N 36 Yk: 10,5 
P: By 758.08 
PMT: @, GG Peyk: 12 


Fe B. BO 
CHOOSE WHEN PAYMENTS BRE MADE 
ekon AHDE] 
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Step 3: Solve for the payment. 


TIME VALUE OF MONEY 
mye 10.5 


: 8,750.08 
-254.40 MALSE 


End 


ENTER PAYMENT AMOUNT OR SOLVE 
ent | [aor [OLVE 


Step 4: Put in -225.00 for the payment and solve for PV to see how 
much Otto can afford to borrow. 


TIME VALUE OF MOWEY 


PeAYR: 12 


Fu: AE End 


ENTER PRESENT VALUE OR SOLVE 
EHT a Ta ETS 


Example: A Mortgage with a Balloon Payment. Russ T. Pipes has 
taken out a 25-year, $75,250 house mortgage at 13.8% 
annual interest. He expects to sell the house in 4 years, 
repaying the loan in a balloon payment. Find the size of 
the balloon payment—the value of the mortgage after 4 
years of payments. 


PV=75,250 
IMYR = 13.8 


N=4x 12 
PYR = 12; End mode 


iv2eyv vay 4 


Balloon 
FV =? | 
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Step 1: Open the Finance Solver (if necessary) and enter values for 
the known TVM variables. 


œ = @) a GeO (if TIME VALUE OF MONEY SESA 
e m 306 YR: 135 

necessary) (œ)€) 300 (ENTER) py 75,250, 06 

13.8 (ENTER) 75250 (ENTER) (M) | pmt: a. a Payk 12 

0 Fue, BG End 


CHOOSE HHEN PAYMENTS ARE MADE 
Pp HODS] OR] | 


Step 2: Find the monthly payment for the 25-year mortgage. 


ow: 


TIME VALUE OF MONEY 
mye 13.8 


© 75,250.00 
Tea reve: 12 
. End 


ENTER PAYMENT AMOUNT OR SOLVE 
EDIT | | par SOLVE} 


Step 3: Calculate the balloon payment needed after 4 years of 
payments. 


(A) (A) 48 (ENTER) (A) SOLVE 28808 TIME VALUE OF MONEY 
N: 48 YR: 13.8 
PY 75, 250,68 
PMT: ~894, 33 PeR: 12 
er SS, End 
ENTER FUTURE VALUE OR SOLVE 
Pept] fans OLve| 


Calculating Amortizations 


Amortization calculations, which also use the TVM variables, 
determine the amounts applied toward principal and interest in a 
payment or series of payments. 


To calculate amortization: 


1. Change the display mode to the accuracy you want, such as 2 Fix 
mode. 

2. Start the Finance Solver. 

3. Check and set these TVM conditions: 
a Number of payments per year. 
m Payments at beginning or end of periods. 
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4. Store values for four TVM variables: J%YR, PV, PMT, and FY. 
These variables define the payment schedule. (You can calculate 
these using the TVM menu.) 

5. Press AMO and enter the number of payments to amortize in 
this batch. 

6. Press Fh to amortize the batch of payments. You will see the 
amount applied to interest, to principal, and the remaining balance 
after this set of payments have been amortized. 


To continue amortizing the loan: 


1. Press EF! to store the new balance after the previous 
amortization as F+, 

2. Enter the number of payments to amortize in the new group. 

3. Press AMOR 


4, Repeat steps 1 through 3 as often as needed. 

To amortize a series of future payments starting at payment p: 
1. Calculate the balance of the loan at payment p—1. 

2. Store the new balance in PV using E+F 

3. Amortize the series of payments starting at the new PV. 


The amortization operation reads the values from the TVM variables, 
rounds the numbers it gets from PV and PMT to the current display 
mode, then calculates the amortization rounded to the same setting. 
The original variables aren’t changed, except for PV, which is updated 
by EF after each amortization. 
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Differential Equations 


The HP 48 can find a solution, y(t), to a differential equation 
expressed as y/(t) = f(t,y), where the initial value of the solution is 
given as y(to) = Yo. 


Solving Differential Equations 
The differential equation solver is part of the SOLVE application. 


To use the SOLVE differential equation solver: 


1. Press (->)GOLVE) 


2. Select Solve diff eq... 


SOLVE WCTI=FCT-VIS 
F: 
INDEP: } INIT: & FINAL: 5 
SOLM: Y INIT: B FIMAL: 


TOL: HGAI ster: DEFIE STIFF 


ENTER FUNCTION OF INDEP AND SOLN 
EMT JCHOOs}] | IMIT+ 


This screen contains the following fields and menu keys: 


Fa Contains the right-hand side of the differential equation 
you want to solve. 


Specifies the independent variable. (Defaults to X.) 


Contains the independent variable’s initial value (to). The 
initial value of the independent variable must correspond 
to the initial value of the solution variable: y(to) = yo. 
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Contains the independent variable’s final value, trina. 
You are trying to solve y(trinaL) = (some unknown). 


Specifies the solution variable. (Defaults to Y.) 
Contains the solution variable’s initial value (yo = y(to)). 


Contains the solution variable’s final value. This is what 
you are trying to solve. You cannot enter a value in this 


field. 


Contains the acceptable level of absolute error. In a 
physical model, select the tolerance to suit the accuracy of 


the data. (Defaults to 0.0001.) 


Contains the initial step size used to compute the solution. 
The calculator uses the Runge-Kutta-Fehlberg method to 
calculate ypinaL-. This method computes its solution by 
automatically stepping from point to point, maintaining 
accuracy at each point. 


STIFF: Selects the stiff solver. 


EDIT Lets you edit a field. 


EREE Lets you select a variable. 


THIT+ Replaces the initial values with current final values. Use 


this to compute the solution at another point using the 
current solution as a starting point. 


SOLVE Solve the differential equation. 


Solving a Standard Initial-Value Problem 


Standard initial-value problems are differential equations that don’t 
require the STIFF solver. To determine how stiff a differential 
equation is, try graphing it before solving it. Very slow graphing may 
indicate that the equation is stiff and the stiff solver should be used. 


To solve a standard initial-value problem: 


Dt Aa ® MR 


Enter an equation or press HOGZ to select an equation. 
Specify the independent variable. 

Enter the initial value for the independent variable. 
Enter the final value for the independent variable. 


Specify the solution variable. 
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6. Enter the initial value for the solution variable. 

7. Enter an acceptable error tolerance. 

8. (Optional:) Enter a step size. Normally, the solver computes an 
appropriate step size. 

9. Press 


G 


Example: Solve this equation for y(1) given that y(0) = 2: 


y =t+y 
(p>) GOLWVE) mM GE SOLVE YCTISFCT.¥ 
(@) TG) @ Y (ENTER) Shee oer 
INDEP: 7 INIT: & FINAL: 1 
(a) T (ENTER) 0 (ENTER) 1 SOLN: YO MT: 2 FINAL: [SSE 
(ENTER) (>) 2 (ENTER) SOLVE TOL: GAGI STEP: DF Lt STIFF 
EDIT 6. 15477799896 
eee 


How accurate is the answer? The general solution to the differential 
equation 


y=tty 
is 
y=ce'—t—1 


Where c is an arbitrary constant. The given initial conditions were 
2 = ce? — 0 — 1. Solving for c and substituting back into the general 
solution, the solution equation is 


y =3e' -t—1 


Solving for y(1), returns 3e — 1 — 1 = 6.15484548538. Comparing the 
results you can see there is an error of approximately 0.000068 which 
is well within the specified error tolerance of 0.0001. 


Solving a Stiff Initial-Value Problem 


Some differential equations may seem to take forever to solve. If this 
happens, the equations may be stiff. Use the stiff function to solve the 
equation. 


To use the stiff function: 


1. Press ()(GOLVE 


2. Select Solue diff eq... 
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3. Highlight = 


SOLVE YUTISFCTAY9 
Fat: FT: 

INDEP: $ INIT: A FINAL: 5 
SOLN: Y INIT: & FINAL: 

TOL: , GAGI ster: Dflt MTIFF 


CALCULATE STIFF DIFFERENTIAL? 
o | — ee 


This screen contains the following additional fields: 


The partial derivative with respect to y of the expression 
in Fi, 


The partial derivative with respect to t of the expression 
in FE. 


19 To solve a stiff initial-value problem: 


D aT A 


S98. EN 


11. 


. Highlight STIFF and press cs CHE. 
. Enter an equation or press CHOOSE to select an equation already 


stored in memory. 

Enter the partial derivatives of the equation with respect to y and 
t (or press CHOS to select them if they are stored in memory). 
Specify the independent. variable. 

Enter the initial value for the independent variable. 

Enter the final value for the independent variable. 

Specify the solution variable. 


. Enter the initial value for the solution variable. 


Enter an acceptable error tolerance. 


. (Optional:) Enter a step size. It is usually best to accept the 


computed default step size. 
Press & E 


Example: Solve this equation for y(1) given that y(0) = 1: 


y' = —1000 * (y — sin(t)) + cos(t) 


This example assumes that the calculator is set to radians. 
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SOLVE WCTISFCT. Y) eae 
m Fat: m l G SFAT: 1G, 
INDEF: T INIT: & FINAL: 1 
SOLM: ‘/ INIT: 1 FINAL: REE 
TOL: BAAI STEP: DF Lt vt STIFF 


pial 1562 169499036 


PL ACL nk | 


The problem takes about a minute to solve. (If you had used the 
standard method, it would have taken over five minutes.) 


How accurate is the answer? With the given initial conditions the 
solution equation is: 


y= e7 1000t 4 sin(t) 


Solving for y(1) gives e7!0°° + sin(1) = 0.841470984808. Comparing 19 
the results, you can see there is an error of approximately 0.000098, 
which is within the specified error tolerance of 0.0001. 


Solving a Vector-Value Differential Equation 


You can use vector-valued equations to solve second-order (or higher) 
differential equations given two or more initial values. 


Another way to write the second-order equation 


y” = ay(t)y’ + ao(t)y + g(t) 


eT = [ay ato 2] 


1 
(t) 
You can then substitute w for i IE fw f or | at al and c for 
r ives 
ij 


which is a first-order differential equation. 


w = fwxwt+cerg(t) 
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Example: Solve this equation for w(1) given that y(0) = 0 and 
y'(0) = 0 (w(0) = [0 0 J): 


y” = 5y + .5y+.5t+1 


Step 1: Convert the equation into a first-order equation: 


p-e eie 


Step 2: 
ep Store the values in fw ( J ) and c H ): 


WM)? Go ! 
(®) .5 (SPC) .5 (ENTER) O) (2) (@) FW (@) (STO) 
AD 0 (SPC) 1 (ENTER) C) (a) C GTO) 


Step 3: Enter the equation and initial values, set the solution 
variable to w, and solve for w(1): 


CEON (VW) OE E SILVE VCTISF(T. V9 
@M@QFweawacew JF FHH+C#<. 5#T+1)' 


INDEP: T INIT: & FIMAL: 1 


WYO)5W@TG)! OLN: b| INIT: E G.. FINAL: 
TIL: BAGI ster: DFlt STIFF 


T (ENTER) 0 (ENTER) 1 PRESS SOLVE FOR FINAL SOLN VALUE 
oe ee [emt] [| | ee ee 
0 0 (ENTER) SOLVE 


Press ERIT to view the result vector, w(1), [ .718262064225 
1.71826206422 ]. The first value is y(1), the second value is y’(1). 


How accurate is the answer? The original equations are 
y=e'-t-1 
and 
y =t+y 


Evaluating the equations at 1 and comparing the results you can see 
there is an error of approximately 0.0000198, which is well within the 
specified error tolerance of 0.0001. 
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You can plot the solution to an initial-value by selecting the 
differential equation option of the PLOT dialog box. 


5 PLOT VCTI=FCTLY S 
TPE Diff E = De 
F: 

INDEP: INIT: ® FINAL: E. & 
SOLM: Y INIT: A _ TIFF 


ENTER FUNCTION OF INDEP AND SOLN 
EDIT [cHODS| | OPTS [ERASE] DRAH] 


This screen contains the following fields and menu keys: 


The plot type (must be & 
ad The angle mode. 

Fa The right side of the equation you want to plot. 
The independent variable. (Defaults to X.) 
The independent variable’s initial value (to). 


The independent variable’s final value. 


The solution variable. (Defaults to Y.) 


The solution variable’s initial value. 


IFF: Selects the stiff solver plot. 
Lets you edit a field. 
Lets you select a variable. 


Lets you control plotting variables. 


Erases previous plots. 


DRAM Creates the plot. 


Press 0} and the following options appear: 
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: PLOT OPTIONS #4 
TOL: REEE STEP: Dlt g 
H-VAR: B H-VEH: -6.5 6.5 
YAR: Í VER: -3,1 3.2 
H-TICK: 1 ¥-TICK: 1A wt PIXELS 
ENTER ABSOLUTE ERROR TOLERANCE 
Es ee ee [ANGL] IE | 


This screen contains the following fields: 
The acceptable error tolerance. 
The step size. 


Whether or not axes are drawn. 


The variable plotted on the horizontal axis. 
ais E The variable plotted on the vertical axis. 

H-VIEMs The portion of the horizontal axis you want to see. 
tey TEk: The portion of the vertical axis you want to see. 
H-TICE: The horizontal tick-marks. 

WeTICK: The vertical tick-marks. 


~PISELS Whether the tick-marks are spaced in user-units or pixels. 


To plot a standard initial-value problem: 


Enter an equation or press ©} 
Specify the independent variable. 

Enter the initial value for the independent. variable. 
Enter the final value for the independent variable. 
Specify the solution variable. 

Enter the initial value for the solution variable. 

Set desired options and view parameters. 


to select an equation. 


NO ew Ne 


Bw 
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Example: Graph y’ = t + y, y(0) = 2, over the interval [ 0, 1 J. 


Step 1: Select PLOT Diff Eq mode, enter the equation, set the 
independent variable to T, and set the initial and final 


values: 
(>) (PLOT) (4) @) DW) PLOT DERT $ 
@QIO@Y @r [Mme Diff Ea «Des 
(ENTER) 0 (ENTER) 1 (ENTER INDEP: T INIT: G FINAL: Ì 
œ)2 SOLN: YO INIT: 2 Wstirr 


USE STIFF DIFF EQ SOLVER? 
o a a OPTS [ERASE DRAH] 


Step 2: Set the horizontal view to range from -1 to 2, set the 
vertical view to range from -2 to 8, and mark the axes every 
user-unit. 


OPTS S) M 1 GA (ENTER) 
2 (ENTER) (>) 2 @/) (ENTER) 8 
(ENTER) 1 (ENTER) 1 (ENTER) 


CHE 


E Se PLOT OPTIONS 
TOL: , DAAL STEF: DF 14 ZARES 
H-¥AR: GO H-VIEH: ~ Í 2 
v-yAk: Í VIER: -2 [z] 
H-TICK: 1 Y-TICK: 1 WpPreLs 


TICK SPACING UNITS ARE PINELS? 
L l o dwche| daNeLj ok | 
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Step 3: Draw the graph. 
GE: ER = 


r 


peper EF 


ELT EE 


You can see that y(1) is approximately 6. This coincides with the 
result from the first example in this chapter. 


Plotting a Stiff Differential Equation 


Use the stiff plot method when equations take a very long time to plot 
or when equations are plotted erratically. Plotting Stiff differential 


equations requires that you enter the partial derivatives of the 
equation. 
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To use the stiff plot function: 


oo 


2. Select D 
3. Highlight _: 


PLOT YUTI=FCT.¥24 
TYPE: Diff Eq á: Deg 
F: BPAY: BRAT: 
INDEF: W INIT: G FINAL: 6, 5 
SOLM: Y INIT: & Eqs TiFF 


USE STIFF DIFF EQ SOLVER? 
L | — a ed DRAH] 


This screen has the same elements that the standard plot has plus the 
following: 


apay The partial derivative with respect to y of the expression 
in Fi. 


GP aT The partial derivative with respect to ¢ of the expression 
in Fe. 


To plot a stiff initial-value problem: 


1. Select STIFF. 

2. Enter an equation or press EHUGS to select an equation. 

3. Enter the partial derivatives of the equation with respect to y and 
t (or press GHETE to select them if they are stored in memory). 

4. Specify the independent variable. 

5. Enter the initial value for the independent. variable. 

6. Enter the final value for the independent variable. 

7. Specify the solution variable. 

8. Enter the initial value for the solution variable. 

9. Set desired options ae view parameters. 

0. Press ; 
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Example: Plot the following equation given that y(0) = 1: 


y = —1000 > (y — sin(t)) + cos(t) 


Step 1: Select stiff, select radians, enter the function, the partial 
derivatives, and the initial values: 


MEDAD MEOR PLOT PETERET) : 
#CHE œ) M 1000 Go lace P ee ee 
: tia aF: 18, aFat | 1B, 
woro QTE) |ime: T mA FINAL: 
S (COS) @) T (ENTER) 1000 |smm: Y mt: i MsTiFF 


x) (COS USE STIFF DIFF EQ SOLVER? 
&) © PJ che] OPTE | 


Step 2: Set the horizontal view to range from -1 to 2, set the vertical 
view to range from -1 to 1, and mark the axes every 10 
pixels: 


pT OM! 
2 CENTER) E)! 1 
10 10 


FEHER 


B HME: -i 
y-yAk: 1  Y-VIEH: —1 1 
H-TICK: 16 oV-TICK: 1@  MPizeLS 
TICK SPACING UNITS ARE PIXELS? 
o | o oec] feaneL | OE 


Step 3: Draw the graph. 


E 
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Plotting a Phase Plane for a Vector-Valued Solution 


The HP 48 also lets you plot vector-valued equations and select which 
vector value is plotted on which axis. As described earlier, another 
way to write the second-order equation 


y” = ar(t)y’ + ao(t)y + g(t) 


w = fwxwtexg(t) 


Where w is HE is E Al and c is He 


The initial condition y/(to) = yo and y(to) = yı can be written w'(to) 
= [ yo yı |. This is a vector-valued initial condition. 


Example: Plot the following equation for w(1) given that y(0) = 0 
and y’(0) = 0 (w(0) = [00)): 
y = 5y + byt 5t+ 1 
where y(0) = 0 and y/(0) = 0 (w(0) = [00]). 


Step 1: Convert the equation into a first-order equation. 


' Jo ally 0 
PF] = [5 sle] ile» 


Step 2: Store the values in fw and c. 


onom: eo! 
aoi 5 GPS) -5 ENTER) C) @) @) FW 
(@) (STO) (4)CD 0 GPc) 1 ENTER) C) @) C 
(To) 
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Step 3: Enter the equation and initial values, set the solution 
variable to w. 


(@) (PLOT) (4) (2) D (¥) PLOT Y ug PT 
MOH W@T 1 INDEF: T INIT: @ CSAT 
(ENTER) (@) T (ENTER) 0 OLN: bf INIT: E Bu STIFF 
(ENTER) | (ENTER) (@) W USE STIFF DIFF EQ SOLVER? 
(ENTER) A 0 (SPC) 0 Ea o ee JERASEL IRAH] 


Step 4: Set the horizontal view to range from -1 to 2, set the vertical 
view to range from -1 to 2, and mark the axes every 0.5 
user-units. 


GETE >) 0) 1C- ENTER) [2 SE PLOT OPTIONS 
2 TER) ©) 1 GE) ENTER) 2 TOL: , ABH STEP: DELE Aves 


H-¥AR: Go H-MEH: — 1 2 
W-¥AR: 1  ¥-VEH: —] 2 
H-TICK: „5 ¥-TICK: 5  WpPiseLs 


TICK SPACING UNITS ARE PIKELS? 
O l o dec) anei ok] 


(ENTER) .5 (ENTER) .5 (ENTER) 


Step 5: Draw the graph. 


aE 


DRAM 


(znori Ee i o o [emrt feae] 


Step 6: Redraw the graph with the second vector value plotted on 
the vertical axis. 


anojn o fo [EMT 
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Calculus and Symbolic Manipulation 


Integration 


You can calculate symbolic integrals for expressions with known 
antiderivatives (indefinite integrals). You can also estimate the 
numeric value of those and other integrals. 


Numeric Integration 


Numeric integration lets you approximate a definite integral— 20 
even when symbolic integration can’t generate a closed-form result. 
Numeric integration employs an iterative numeric procedure to obtain 

the approximation. 


To find the value of an integral with numeric limits: 
1. Press @)(GYMBOLIC) GE. to open the INTEGRATE form. 


2. Enter the expression to be integrated in the EXFR: field (without 
the integral sign). 


4. Enter the limits of integration in the LG! and } fields. For 
numeric integration, the limits must be numbers or algebraic 
expressions that evaluate to numbers. 

5. Make sure the 


T field says MM 
necessary.) You will see the | 


z (press (*/-), if 

` field appear when 
the result type is z. It is important because the number 
display format determines the accuracy factor for the numeric 
integration. 
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AR: 
RESULT: Humer ic 


HUMBER FORMAT: Std 


ENTER EXPRESSION 
EDIT [CRD | [CANC] OK | 


The Numeric INTEGRATE Screen. 


6. Set the number display format to indicate the accuracy factor you 
desire for the computation. The t«i format yields the highest 
accuracy factor lane consequently the longest calculation time) 

a 3 +) yields the lowest accuracy factor 
(and the shortest calculation time). See “The Accuracy Factor and 
the Uncertainty of Numerical Integration” on page 20-6. 
. Press “to compute the integral. 
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Improper integrals are those integrals where one or both limits are 
infinity (cc). The HP 48 is a calculator with finite computational 
limits and thus must always use finite limits when computing numeric 
integrals. However, by using a transformation of variables, you can 
map an unbounded domain onto a bounded one. 


One useful transformation, Y = arctan x, maps the entire real x-axis 
onto the bounded interval =" < y < 5. This is the transformation: 
pOO arctanw= 
| fird — f(tan y) (1+ tan ?y)dy 
-œ arctan—oo= 55 


To evaluate an improper integral: 


1. Make sure that you are in Radian mode (press ()(RAD), if 
necessary). 

2. Press (>)(SYMBOLIC) “to open the ] 

3. Enter the integrand from the improper integral into the £ 
field. 

4. With the E field highlighted, press 
the transformation expression onto the stack. For example, if the 
variable of integration for the improper integral is 1, you would 
enter » to make the transformation (£ = tan y) shown 
above. Make a extra copy of transformation expression by pressing 


ENTER) a second time. 


form. 


and enter 
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11. 


12. 


13. 


. Press 


Enter the name of the original integration variable in the improper 
integral and press (STO). 

Enter the name of the new integration variable and press ()(6) 
to compute the derivative of the transformation expression with 
respect to the new integration variable. 

Press (x) (EVAL) to compute the transformed integrand 
and return it to the f ë field. 

Enter the new variable of integration into the + field. 

Enter the lower limit of integration into the Li: field. Use 

' ' wherever you need to include oo 

i, transform the limit, and press Gk to return. 
For the arctangent transformation above, y = arctan z, you must 
find the arctangent of the limit to transform it. Note that this 
function is the inverse of that used to transform the expression 
above. 


Repeat the previous two steps for the upper limit, beginning and 
ending in the HI: field. 

Make sure that the result type is Hurri and set the desired 
number format. 

Press GE... to compute the numeric integral. 


Example: Compute the following improper integral: 


oy 
| zæ + p” 


Step 1: Open the IHTEGEATE form and enter the integrand of the 


improper integral. 


EWANI OOQ 
oO (e)X G) 1 ENTER) 


VARE 
RESULT: Symboli ic 


ENTER EXPRESSION 
EDIT [coni ANCL] OK] 
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Step 2: Use CALC to access the stack, enter and duplicate the 
transformation expression. 


xD CALC CCAM @Y ja: 'LeCHe C41)! 
e TENCO) 
ets eee eee eNe Ok 


Step 3: Transform the variable of integration, purge Y to ensure 
a symbolic result, and compute the derivative of the 
transformation expression. 


QX 
C @)Y (ENTER) (ENTER) 
(DEURS) (>) (6) 


Le tael at] yy! 
‘1+TANCY 2! 
sO C2 ok | 


Step 4: Multiply the derivative of the transformation expression 
20 by the integrand, evaluate to effect the transformation and 
return the result to the ESPR: field. 


Ok 


NTEGRATE 


RESULT: Symboli ic 


ENTER EXPRESSION 
RESET) CALC [TYPES] ANCL] Ok | 


Step 5: Enter the new variable of integration, then compute and 
enter the transformed limits. 


DOY (ENTER) 

CALE eons QE 
wD T 
DEN ) CONT) OE 


EXPR: 7 CTANCY)# TAH 
VaR: Y «fou. HE BIE 
RESULT: Sumbal ic 


ENTER UPPER LIMIT 
RESET) CALC ITVPES] AIL] OK | 


Step 6: Change the result type to } ic, set the display to : 


and compute the integral. 
Maw 1: 693147188555 
(until = hed is displayed) [VECTRA MATR] LIST | HYP | REAL 
Cie 
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To evaluate a multiple integrai numerically: 


1. Press (4)(EQUATION), key in the multiple integral (include all 
integral signs), and press (ENTER). All limits must evaluate to a 
number. 


2. Set the number display format to reflect the desired accuracy. 


3. Press (NUM) to compute the result. 


Example: Find the area of the region enclosed by the cardioid, 
r = 1—cosé@. The region can be expressed by the double 


integral: 
20 l—cosé@ 
l l r dr dé 
JO 0 


Step 1: Key in the double integral using the EquationWriter. 


() EQUATION) (>) VY) 0 &) 2 


OOMOO 2 f1-Cosca) 
CONME)FHOOHR Fi rdr deo 
MHODROO OM 

VECTRIMATR] List | HYP [REAL | EASE 


Step 2: Enter the double integral onto the stack and set the display 
mode to Fix 3 and the angle mode to Radians. 


l: poorest hee 
(MODES) 3 °F DR sal da 
(4D (RAD) (if necessary) Eli s| ci LENG | Ftd- (til = 


Step 3: Evaluate the double integral. Then test your suspicion that 
m might be a factor in the result. 


Ga) GNuM) ENTER) z: 4.712 


(4) (SYMBOLIC) (NXT) #8 : geet! 
Perat[+ Mat] +e [sem] APPLY] 


Calculus and Symbolic Manipulation 20-5 


20 


20 


The Accuracy Factor and the Uncertainty of Numerical 
Integration 


Numeric integration calculates the integral of a function f(x) by 
computing a weighted average of the function’s values at many values 
of x (sample points) within the interval of integration. The accuracy 
of the result depends on the number of sample points considered: 
generally, more sample points provide greater accuracy. There are two 
reasons why you might want to limit the accuracy of the integral: 


m The length of time to calculate the integral increases as the number 
of sample points increases. 

m There are inherent inaccuracies in each calculated value of f(x): 
ci Experimentally derived constants in f(x) may be inaccurate. 
For example, if f(x) contains experimentally derived constants 
that are accurate to only two decimal places, it is of little value 
to calculate the integral to the full (12-digit) precision of the 
calculator. 

ci If f(x) models a physical system, there may be inaccuracies in the 

model. 

o The calculator itself introduces round-off error into each 
computation of f(x). 


To indirectly limit the accuracy of the integral, you specify the 

accuracy factor of the integrand f(x), defined as: 

true value of f(x) — computed value of f(x) 
computed value of f(x) 


accuracy factor < 


The accuracy factor is your estimation in decimal form of the error 

in each computed value of f(x). You specify the accuracy factor by 
setting the Display mode to n Fix. For example, if you set the display 
mode to 2 Fix, the accuracy factor is 0.01, or 1%. If you set the 
display mode to 5 Fix, the accuracy factor is 0.00001, or .001%. 


The accuracy factor is related to the uncertainty of integration (a 
measurement of the accuracy of the integral) by: 


uncertainty of integration < accuracy factor x / |f(x)|dz 
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The striped area is the value of the integral. The shaded area is the 
value of the uncertainty of integration. You can see that at any point 20 
xz, the uncertainty of integration is proportional to f(x). 


The numeric integration algorithm uses an iterative method, doubling 
the number of sample points in each successive iteration. When the 
algorithm stops, the current value of the integral is returned to level 
1, and the uncertainty of integration is stored in the variable JERR. 
The error in the final value will almost certainly be less than the 
uncertainty of integration. 


To check the uncertainty of the numeric results: 


(you may 


a After computing the numeric results, press 
i is displayed in 


need to press one or more times before 
the menu. 


Symbolic Integration 


Symbolic integration means calculating an integral by finding a known 
antiderivative and then substituting specified limits of integration. 
The result is a symbolic expression. 


The HP 48 can integrate the following patterns: 


a All built-in functions whose antiderivatives contain only built-in 
functions (and whose arguments are linear). See the analytic 
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functions, labeled with “A” in appendix G. For example, 
> RISC AA. 
m Sums, differences, negations, and other selected patent 
of such functions. For eto ; 
s*, and! 


LAE 


a Derivatives of all built-in functions. For example, ‘IH¥ei+; 


To find the definite integral with symbolic limits: 


1. Press (@)(SYMBOLIC) GE to open the I 


INTEGRATE 


RESULT: Symboli ic 


ENTER EXPRESSION 
EMIT [ckone | CTC ok 


The Symbolic INTEGRATE Screen. 


2. Enter the expression to be integrated in the EPR: field (without 
the integral sign). 

3. Enter the variable of integration in the AF: field. 

4. Enter the limits of integration in the Lū: and HI: fields. If you 
want to use formal variables for limits, be sure that the variables do 


not exist in the current directory. 


5. Make sure the RESULT field says Sumbolic (press „if 
necessary.) 
6. Press to compute the integral. If the result is a closed-form 


expression—if there is no / sign in the result—the symbolic 
integration was successful. If the result still contains f, you can try 
rearranging the expression and evaluating again. If rearranging fails 
to produce a closed-form result, you can estimate the answer with 
numeric integration or approximate the symbolic integral using a 
Taylor’s polynomial (see “Taylor Polynomial Approximation,” on 
page 20-12). 
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7. Press to simplify the closed-form result. 


To find the indefinite integral of a function: 


1. Press ()(SYMBOLIC) to open the f 


2. Enter the expression to be integrated in the 
the integral sign). 

3. Enter the variable of integration in the 4 field. Make sure that 
this variable is formal—that it doesn’t etist. in the current directory. 

4. Enter 0 as the lower limit and the variable of integration as the 
upper limit. 


field (without 


5. Make sure the & „T field says : (press 4/-), if 
necessary. ) 
6. Press = GE. to compute the closed-form expression. 


7. W ui the closed-form expression on level 1 of the stack, press 
a 3 ()GTACK) (NXT) GEPH. to discard the lower 
limite. 


8. Press (EVAL) to evaluate the result at the upper limit. 


To symbolically integrate an expression that’s not integrable 


1. Derive a Taylor’s polynomial approximation to the integrand. 
2. Find the symbolic integral of the Taylor’s polynomial. 


Differentiation 


You can differentiate a symbolic expression either one step at a time, 
so you can see the substitutions—or completely in one step, so you can 
go right to the final result. If your expression contains only analytic 
functions (those labeled with “A” in appendix G), you get an explicit 
derivative. 


To find the derivative of a function at a specified point: 


1. Press (@)(SYMBOLIC) (F) -EE to open the & 


form. 
2. Enter the function into the #8 field. 
. Enter the variable of differentiation into the Ff 
4. Press (*/-), if necessary, to change the result type to H 


Ww 


field. 
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DIFFERENTIATE & 


EXPE: 
YAR: 
RESULT: Humer ic 
VALUE: 


ENTER EXPRESSIOM 
EDIT [CHOO2] | STEP |CANCL| OF | 


The Numeric DIFFERENTIATE Screen 


5. Enter the value at which you want to compute the derivative into 
the 2 field. 
6. Press 


To symbolically differentiate an expression completely in one step: 


1. Press (@)(SYMBOLIC) (¥) GE to open the 


form. 


DIFFERENTIATE 
EXPR: 

VAR: 

RESULT: Symbolic 


ENTER EXPRESSION 
EDIT [CHODS] | 2TEP CAMCL] OF _| 


The Symbolic DIFFERENTIATE Screen 


2. Enter the function into the EPR: field. 
3. Enter the variable of differentiation into the 
4, Press . GE 


To symbolically differentiate an expression step-by-step: 


1. Press ()GYMBOLIC) (¥) 
form. 

. Enter the function into the ESPR: field. 

3. Enter the variable of differentiation into the 

4. Press cF, The first step of the derivative 
and returned to the stack. 

5. Press repeatedly to advance the evaluation of the derivative 
step-by-step. 


to open the 


field. 
will be computed 
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Creating User-Defined Derivatives 


If you execute ô for a function that has no built-in derivative, ð 
returns a new function whose name is der followed by the original 
function name. The new function has arguments that are the 
arguments of the original function, plus the arguments’ derivatives. 
(You can differentiate further by creating a user-defined function to 
represent the new derivative function.) 


If you execute ð for a formal user function (a name followed by 
arguments in parentheses, for which no user-defined function exists 
in user memory), ô returns a formal derivative whose name is der 
followed by the original user function name, plus the arguments and 
their derivatives. 


Example: The HP 48 definition of % does not include a derivative. 
If you enter | & »‘f3' and press (EVAL), you get 


ee Pe gle hos ake yao! 


hate 


Each argument of the % function results in two arguments 
for the der% func tions $ results in # and 32, and Y 
results in y and 42c}, 


To define the derivative function for %, you can enter 


a ppt ett and press 
acD 


will appear in your VAR menu. 


Example: Enter the derivative ot a formal user function, 
2'. Then evaluate it by pressing 


(EVAL). The result is this: 
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Implicit Differentiation 


An implicit function of, say, x and y is a function in which one of the 
variables (y) is not directly expressed in terms of the other variable 
(f). This may be because it is either impossible, difficult, or not at all 
obvious how the expression may be solved for one variable in terms 
of the other. When this happens it is still possible to differentiate the 
expression using normal rules of differentiation (and the chain rule). 


To perform implicit differentiation: 


1. Enter the implicit function onto the stack. Instead of using two 
independent variables (such as z and y), make the second variable 
dependent on the first (such as x and y(x)). This links the two 
variables appropriately so that the differentiation treats the 
function as implicit, instead of eliminating one of the variables as a 
constant. 

2. Enter the variable of differentiation onto the stack (using the 


i 


delimiters). 
3. Press ()(6) to compute the implicit derivative. You may see a 
user-defined derivative (such as demts, 13) included in the result. 


This is the way the HP 48 expresses the derivative of one variable 
with respect to the other (such as a). 


Taylor Polynomial ‘Approximation 


For any mathematical function represented by a symbolic expression, 
you can compute a Taylor’s polynomial approximation about x = 0, 
sometimes called a Maclaurin series. You can also specify the order of 
the polynomial. 


To derive the Taylor’s polynomial approximation about x = 0: 


1. Press ()(SYMBOLIC) (¥)(¥) GE to open the T 


4T AL. form. 


POL 
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TAYLOR POLYNOMIAL & 


EX 
VAR: ORDER: 
RESULT: Numeric 


ENTER EXPRESSIOM 
EWT (choos |  [CANiL| Ok | 


The TAYLOR POLYNOMIAL Screen 


2. Enter the function you wish to approximate into the EHF: field. 

3. Enter the name of the variable to be used in the Taylor polynomial 
into the WAR: field. 

4. Enter the order of the Taylor polynomial into the ORDER: field. 
Note that higher order polynomials require more time to compute. 

5. Press GE to derive the Taylor polynomial approximation. 


TAYLR always evaluates the function and its derivatives at zero. If 
you’re interested in a function’s behavior in a region away from zero, 
the Taylor’s polynomial is more useful if you translate the point of 
evaluation to that region, as described below. Also, if the function 
has no derivative at zero, its Taylor’s polynomial will be meaningless 
unless you translate the point of evaluation away from zero. 


To derive the Taylor’s polynomial approximation about x = a: 


1. Press (¢>)(SYMBOLIC)(¥)(¥) GE to open the TAYLOR 
POLY HOMIAL form. 

2. Enter the function you wish to approximate into the EFF: field 
and press (ENTER). 

3. Press (A) {ALG and enter '‘'+a' on to the stack, where a 
is the point at which you are deriving the polynomial. Note that ‘ 
(or whatever name you wish to use instead) must not exist in the 
current directory path. 

4. Press C) (@)X GE to store the translation, 
reevaluate the function using the translation, and return the result 
to the EXFR: field. 

5. Enter the name of the new variable (‘') to be used in the Taylor’s 
polynomial into the VAF: field. 

6. Enter the order of the Taylor’s polynomial into the ORDER: field. 
Note that higher order polynomials require more time to compute, 
but result in better approximations. 
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7. Press GE to derive the Taylor’s polynomial approximation for 

the translated point. 

Press C) = ()(@uRs) to purge the % variable. 

9. Enter '#~a' onto the stack and press C) (@)Y to store it in 
y. (If you used a different dummy variable name, use it in place of 
t here.) 

10. Press to change the variable back to the original %. You 
may also wish to press (€)(SYMBOLIC) CULT to simplify the 


results. 


Co 


Finding Symbolic Solutions to Equations 


A common goal of algebraic manipulation of an expression or equation 
is to “solve for” a variable symbolically—that is, to express one 
variable in terms of the other variables and numbers in the expression 
or equation. You can solve symbolically using these commands: 


w ISOL. Solves for a variable that appears only once in any type of 
expression or equation. 

m QUAD. Solves for a variable that appears in a quadratic expression 
or equation. 


Comparison of Commands for Symbolic Solutions 


QUAD Command 


Variable can appear several 
times—no rearranging required. 


ISOL Command 


Variable appears only once. 


Variable can be any order. 
Variable must not be higher than 
second order for an exact 
solution. 


Variable can be the argument of a 
nonlinear function (such as SIN). 
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Isolating a Single Variable 


To solve for a variable that appears only once: 


1. 


on 


6. 


Press (> )(SYMBOLIC) (¥) M) (¥) Ek to open the | 
- form. 
Enter the expression or equation to be solved into the : field. 
If the algebraic is an expression (it has no =), the expression is 
treated as an equation of the form | expression=&'. 
Enter the variable you wish to solve for into the +: field. The 
variable to be isolated can be the argument of a function only if the 
HP 48 has an inverse for that function. Functions for which the 
HP 48 has inverses are called analytic functions in this mandal For 
example, you can isolate X in an algebraic containing E 
i i2 because TAN and LN have inverses (ATAN and EXP 
However, you cannot isolate X in an algebraic containing I Ds 
The operations index in appendix H identifies the HP 48 analytic 
functions, 
Optional: Select the result type you wish. (Mumeric will attempt 
to compute a numerical solution and generate an error message if it 
fails.) 
Optional: Check the FE THC IFAL field if you only want to see the 
principal solution (see “Getting General and Principal Solutions” 
on page 20-16). 
Press  (& to solve for the variable. 


Solving Quadratic Equations 


To solve for a variable in a quadratic: 


1. 


Press (p>) (SYMBOLIC) (A) (A) GE to open the £ 


pi © form. 


; Enter thé quadratic equation or expression you wish to solve in the 


“PR: field. If the algebraic is an expression, the expression is 
treated as an equation of the form ‘ erpression=&'. If you supply 
an equation that is not first or second order in the variable to be 
solved for, it will be transformed into a second order polynomial 
approrimation before being solved as a quadratic 

Enter the variable you wish to solve for in the ¥# field. If the 
algebraic contains other variables, they must not exist in the 
current directory if you want those variables to be included in the 
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solution as formal (symbolic) variables. If they exist in the current 
directory, they are evaluated when the quadratic is solved. (Purge a 
variable to make it formal.) 

4. Optional: Select the result type you wish. (Humeric will attempt 
to compute a numerical solution and generate an error message if it 
fails.) 

5. Optional: Check the FEIHZIFAL field if you only want to see the 
principal solution (see below). 

6. Press © QE to solve the quadratic. 


Getting General and Principal Solutions 


HP 48 analytic functions always return one result—the principal 
solution. For example, V4 always returns +2, and ASIN(.5) always 
returns 30 degrees or 0.524 radians. 


However, when you solve an algebraic for a variable, there may be 
more than one solution—and you may want to know what they 
are. So the ISOL and QUAD commands normally return a general 
solution. A general solution represents the multiple solutions by 
including special variables that can take on multiple values: 


m s{ represents an arbitrary + or — sign (+1 or —1). Additional 
arbitrary signs in the result are indicated by s2, s3, ... . The 
“principal” value for arbitrary signs is +1. 


m ni represents an arbitrary integer—0, +1, +2, ... . Additional 
arbitrary integers are represented by n2, n3, ... . The “principal” 
value for arbitrary integers is 0. 


To specify general or principal solutions while viewing the stack: 


1. Press (Œ (Modes) FLAG. 


2. Press EHE until the desired option is displayed for Flag -1. 


Example: Using ISOL to isolate z in the equation y = sin x”, gives 
the following results when general and principal solution 
options are chosen (in Radians mode): 


Principal Solution: 'H=fASIMeY2'. 


General Solution: 'H=s1 [ASIH Y 3#. 
Llicnmitwenia' 
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Showing Hidden Variables 


Sometimes you may want to solve for a variable that’s stored in 
another variable. To do this, you have to convert the algebraic so the 
hidden variable is visible. 


Sometimes you may want to speed evaluation by converting an 
algebraic so all variables except certain ones are evaluated. 


To evaluate only specified variables in an expression: 


1. Enter the expression onto the stack. 
2. Do one of the following: 
m Enter the name (with ' delimiters) of the variable in the 
expression that you do want to evaluate. 
m Enter a list containing the variable names in the expression that 
you do not want evaluated. 
3. Press ()(SYMBOLIC) SHOW. The expression will be partially 


evaluated according to your wishes in step 2. 


To evaluate an algebraic for temporary variable values: 


1. Enter the algebraic onto the stack. 
2. Enter a list that contains each variable name followed by the value 


to substitute. For example: £ name, exprj... NAME ELPTy * 
where expr can be a number or a symbolic expression. 
3. Press ()(SYMBOLIC | to perform the evaluation. If a 


variable named in the list currently exists (in the VAR menu), its 
contents are not changed by the | (“where”) function. 


Rearranging Symbolic Expressions 


Manipulating Whole Expressions 


You can sometimes simplify algebraics by expanding subexpressions or 
collecting like terms. For example, if a variable occurs more than once 
in an algebraic, you may be able to simplify it so the variable occurs 
only once—letting you use ISOL to solve for the variable. 
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A subexpression consists of a function and its arguments. The 
function that defines a subexpression is called the top-level function 
for that subexpression—it’s the function that’s executed last. For 
example, in the Ta 'A+becef' the top level function for the 
subexpression -, the top-level function for : 


and the top level Raton A Fei 


` js +. 


To collect like terms in an algebraic: 


a Enter the expression onto the stack and press (4) (SYMBOLIC) 
p. COLCT simplifies an algebraic by doing the following: 
o Evaluates numerical subexpressions. For example, 
: COLETE returns 4. 
a Collects numerical terms. For example, `i 


ci Orders factors (arguments of +) and combines like factors. For 


example, oc Tay! DOLET returns AOC TRAG wy a] 
5 Orders summands (arguments of + or —) and combines like 
terms differing only in a coefficient. For example, ‘s+8+¥+5 


KEF 


GHEET returns 


COLCT operates separately on the two sides of an equation, so like 
terms on the opposite sides of the equation are not combined. 


To expand products and powers in an algebraic: 


m Enter the expression onto the stack and press (11) (SYMBOLIC) 
ESPA EXPAN rewrites an algebraic by doing the following: 
© Distributes sides anes and division over addition. For 
example, 'H#ecB+t: FR returns 'F 
o Expands powers over sums. For example, 
returns `F FA 
© Expands positive power ma For exaropie; 
returns ' ht and ' Ar 


EXPAN doesn’t carry out all possible expansions of an algebraic 
in a single execution. Instead, EXPAN works down through the 
subexpression hierarchy, stopping in each branch of the hierarchy 
when it finds a subexpression that it can expand. It first examines 
the top-level subexpression (the top level subexpression is the 
algebraic itself). If it’s suitable for expansion, EXPAN expands 

it and stops—otherwise, EXPAN examines all of the second-level 
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subexpressions. This process continues until an expansion occurs at 
some level—no lower levels are checked. 


Manipulating Subexpressions 


You can rearrange an algebraic in specific step-by-step stages, letting 
you get the result in the form you want. The Rules transformations 
are algebraic-rearrangement operations that are narrower in their 
scope than EXPAN and COLCT. The Rules transformations let you 
direct the path of an algebraic rearrangement. 


To algebraically rearrange a particular subexpression: 


1. Put the algebraic in the Equation Writer application: 
a To enter a new algebraic, press (|) (EQUATION) and key it in. 
m To use an algebraic in level 1, press (F). 
w To use an algebraic stored in a variable, press the VAR, menu key 
associated with the variable and press (¥). 

2. Get the Selection environment: 20 

m From entry mode, press (€). 
a From scrolling mode, press (€)(PICTURE) (8). 

3. Press (A) (¥) 4) Œ) to move the selection cursor to the top-level 
function for the subexpression you want to rearrange. (See below.) 

4. Optional: Press EXPE at any time to highlight the current 
subexpression in its entirety (the highlight turns on or off). 

5. Press RULES to get the RULES menu. (You can press ©) to return 
to the Selection menu.) 

6. Press the menu key for the transformation you want (or just move 
the cursor to not do a transformation). Press (g>) before any 
transformation key to execute the transformation repeatedly until 
no further change occurs. 

7. Repeat step 6 for each transformation you want. (If you move the 
cursor, you have to go back to step 3.) 


8. Press (ENTER) to save the transformed algebraic (or press (CANCEL 


to not save it). 


In this section, the definition of subexpression in the previous section 
is expanded to include individual objects. For example, you can 
specify a name as the subexpression. 


After you activate the Selection environment, you move the 
selection cursor—it specifies both an object in the algebraic and its 
corresponding subexpression. 
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Operations in the Selection Environment 


Description 


Selects a menu of relevant rearrangement 
transformations for the specified subexpression. 
ERT Returns the specified subexpression to the command 
line for editing. 

Highlights the specified subexpression. 


Returns the specified subexpression to level 1 of the 
stack. 

Replaces the specified subexpression with the algebraic 
in level 1 of the stack. (See “Replacing a Subexpression 
with an Algebraic Object” on page 7-12.) 

Exits the Selection environment, restoring the entry 
mode cursor at the end of the equation. 

(A) (¥) Moves the selection cursor to the next object in the 
(<4) (>) indicated direction. When prefixed with (>), moves 
the selection cursor to the farthest object in the 
indicated direction. 

+- Highlights the specified subexpression (just like 

EPRE ), but is also active when the RULES menu is 
displayed. 


The RULES menu may include transformations that aren’t applicable 
to the specified subexpression—such menu keys produce a beep. After 
you execute a transformation, the selection cursor highlights the new 
top level object. The RULES menu is removed whenever you press 
any of the following keys: (49) œ) (4) (¥), ©) (to return to the Selection 


menu), (ENTER), or (CANCEL). 


The tables on the next several pages describe the Rules 
transformations and show examples. However, the tables do not 
include all patterns for which transformations are applicable. 
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Note 


The following tables include examples of 
transformations in the form 


before — after 


The before and after algebraics are shown in their 
command-line form—even though you execute Rules 
transformations in the EquationWriter environment. 


If you try an example, press (ENTER) to see the new 
expression in command-line form. 


The RULES Menu— Universal Transformations 


Description 


Double-negate. 


pa 


A — A 


“4 Raise to the power 1. 


Double-invert. 

A — THY OTHERS 
Multiply by 1. 

AS et 

AtB Si — ATE 


A ASI 

Divide by 1. 

H — Ae 

Atk | — ACE 

Add 1 and subtract 1. 


Al Aisi 


Collect. Executes a limited form of the COLCT 
command in the SYMBOLIC menu. Works only on the 
subexpression defined by the specified object and 
leaves the coefficients of collected terms as sums or 
differences. 
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The RULES Menu— Moving Terms 


Key Description 


ET Move-term-left. Moves the nearest neighbor to the 
right of the specified function over the nearest neighbor 
to the left of the function. 


— Pp o EREI 


+ Move-term-right. Moves the nearest neighbor to the 
left of the specified function over the nearest neighbor 


20 eTo and T+. are used to move a term over its “nearest 
neighbor” to the left or right. A term is an argument of + or — (a 
summand), an argument of * or / (a factor), or an argument of =. 
Also, these two operations ignore parentheses—you can make them 
respect parentheses by executing #1 to make the parenthetical 
subexpression a term. 
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The RULES Menu—Building and Moving Parentheses 


Description 


Key 


Parenthesize-neighbors. Parenthesizes the nearest 
neighbors of + or «. Has no effect if the specified 
function is the first (or only) function in the 

expression, because these parentheses are already 
present, but hidden. 


r be’ E 


Expand-subexpression-left. Expands the subexpression 
associated with the specified function to include the 
next term to the left. Note that a matched pair of 
parentheses may disappear. 


E — ASCE 


VE 


Expand-subexpression-right. Expands the 
subexpression associated with the specified function to 
include the next term to the right. 

A RERED + +E — A+ EBACE +E 


The RULES Menu—Commuting, Associating, and 
Distributing 


Description 
Commute. Commutes the arguments of the specified 
function. 
HEE — E+A 


TRR TEGED 
FETS EFi 3 


ge S a 


Associate-right. 


Co Ai B+o3 


Distribute-prefix-function. 


f — -fpf 


Calculus and Symbolic Manipulation 20-23 


20 


20 


The RULES Menu—Commuting, Associating, and 


Distributing (continued) 


Key Description 
eo Distribute-left. 
Es ab 
> LHCAOELHCE 
ap Merge- ee. Merges arguments of +, —, x, and 


/, where the arguments have a common factor or a 
common single-argument function EXP, ALOG, LN, or 
LOG. For common factors, the + indicates that the 
left-hand factors are common. Also merges sums where 
only one argument is a product. 

CARB ECAD! — ASC B+03 

; EXP CR+E 


Rim AECL t+eo 


Merge-factors-right. Merges arguments of +, —, *, and 
/, where the arguments have a common factor. The + 
indicates that the right-hand factors are common. Also 
merges sums where only one argument is a product. 
CASC+ Chel — CA+B pee 


Hapi sE — CA4+12Se 


Double-negate and distribute. Equivalent to BHEG 
followed by § #4 on the resulting inner negation. 


Double-invert and distribute. Equivalent to IM 
followed ee on the resulting inner inversion. 
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The RULES Menu—Rearranging Exponentials 


Description 


Replace log-of-power with product-of-log. 


product-of-log with log-of-power. 


Replace 


Replace 


Replace exponential with trigonometric functions. 
(This example assumes Radians mode.) 


20. 


Description 


Add fractions. Combines terms over a common 
denominator. (If the denominator is already common 
between two fractions, use H+.) 


E 3 — iÑ 


The RULES Menu—Expanding Trigonometric Functions 


Key Description 


Expand-trigonometric-definition. Replaces 
trigonometric, hyperbolic, inverse trigonometric, and 
inverse hyperbolic functions with their definitions in 
terms of EXP and LN. (These examples assume 
Radians mode.) 


Expand as product-of-trigonometric-functions. 
Expands trigonometric functions of sums and 
differences 
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The RULES Menu— Automatic Multiple Execution 


Key Description 


Dt Multiple-distribute-right. 


S sisibale left. 


> — Rafe 


AS M Tens 


EF Multiple- -associate-left. 
iy PER a8 


| Multiple- mer eok left. 


por Niilon: move-term-right. 


E] Multiple-move-term-left. 


©) 
G2 
(ce) 
©) 
(p>) HS Multiple-merge-factors-right. 
G2 
œ 
e) 
fa) 


ae Multiple-expand-subexpression right. 
PEERED DHE — Phi Bee 5 


C+ Multiple-expand-subexpression-left. 


Example: Solve for the variable x in the equation 
az = be+e 


Do this by rearranging the equation so z appears only 
once, then using ISOL. 


Step 1: Select the EquationWriter application and key in the 
expression. 


(&) EQUATION) 
SCRIOS 
BAACH 
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Step 2: Activate the Selection environment. Then move the selection 
cursor to the = sign and get the RULES menu. 


5 
(€) (5 times) 


Step 8: Move the term E* to the left side of the = sign. 


Aamo =C 


pet | T> [en |m» | ar [ es | 


Step 4: Merge the two terms on the left side of the = sign. 
No 


CA-B) =C 


Step 5: Now that z occurs only once in the equation, put the 
equation on the stack and isolate z. 


Making User-Defined Transformations 


If the built-in Rules transformations do not rearrange an algebraic 

in the form you want, you can make your own transformations. A 
“custom” transformation replaces occurrences of a pattern with a new 
pattern. The pattern can be specific or it can contain “wildcards” that 
match any subexpression and that you can reinsert in the replacement. 
You’re informed whether or not a replacement was made. 
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You can also make conditional transformations—whether they occur 
depends on a condition you specify. 


To replace a subexpression with a different subexpression: 


i 


CA 


. Enter the 


Press (>) (SYMBOLIC) (A) -£= to display the 
E 4 form. 
Press HATE to open the Hi 


OH form. 
Enter or insert the expression you wish to modify in the E 


field. (You may insert an expression on level 1 of the stack by 
pressing (NXT) CALI (NXT).) 

ymbolic patton that you wish to replace in 

the : field. For generalized transformations, the 
search pattern can contain “wildcard” names that match any 
subexpressions. A wildcard name consists of an & character 
((@)(4)(ENTER)), and a valid variable name (24, && 
are examples). 

rae me new, ae cea ymo expression in the 


iphon expression, you should use wildcards in the nat 
expression. You may not use a wildcard in the replacement 
expression that you did not use in the pattern expression. 


. Optional: Put a check-mark in the SUBEXFE FIRST field if 


you want the search-and-replace to begin at the lowest level of 
subexpressions and work “upwards” to the overall expression—a 
good option if the substitution will simplify the expression. Leave 
the field unchecked to begin the search with the overall expression 
and work “downwards” to the lower levels of subexpressions—-a 
good option if the substitution will expand the expression. Note 
that a subexpression that already has been matched (and thus 
replaced) is not a candidate for any further matches, nor are any 
subexpressions whose arguments already have been matched. 
Optional. Enter an expression representing a conditional test (such 
as å :). The replacement will occur only if the test is true. 


. Press = (Eto execute the search-and-replace in the chosen 


“direction” and according to the conditional test, if any. 
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Example: An extension of the half-angle formula for sine is 
sin(2z) = 2sin(z) cos(z) 
Create a transformation based on this formula and use it 
to transform the expression 'SIHtZ#¢s+123' 
Step 1: Open the MATCH EXPRESS1IOH form and enter the target 
expression into the EXFE: field. 


()GvmBoLIc) A) OE 
mT Om OO 
@)X G7 ENTER) 


MATCH EXPRESSION Š 
ERPR: 'SINC2¥Cxt+1 940 
PATTERN: 

REPLACEMENT: 
_SUBERPR FIRST COND: 


ENTER PATTERN TO SEARCH FOR 
[emt o ooo Po aneh okei 


Step 2: Enter the pattern and replacement expressions, using a 
P P P p g 
wildcard for z in the formulas. 


OGD? BOE 

(@)Z ENTER) C) 2 & Gin) 

ommna ©) 
Z 


MATCH EXPRESSION Š 
EXPR: ‘SINC 2¥CH+159 
PATTERN: SINC 2#8.2 3! 

REPLACEMENT: 'S¥SINCR 2S, 


(@) (4) (ENTER) (@) Msueexre FIRST COND: 
ENTER). SEARCH SUBEXPRESSIONS FIRST? 


Es CANeL | OE 


Step 3: Leave SUBENPE FIRST unchecked and do not include a 
conditional test. Execute the search-and-replace. 


MANIPULATE EXPRESSION 
EEE E DE EAE 


ENTER EXPRESSION 
Petit [cons | [MATC|COLCTT ENP | 
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Symbolic Integration Patterns 


This table lists the symbolic integration patterns used by the HP 48. 
These are the integrands that the HP 48 can integrate symbolically. 


¢ is a linear function of the variable of integration. The antiderivatives 
should be divided by the first-order coefficient in ¢ to reduce the 
expression to its simplest form. Also, patterns beginning with 1/ 


match INV: for example, 1/¢ is the same as INV(¢). 


Symbolic Integration 


Pattern Antiderivative 
ACOS($) ex ACOS(¢)—//(1-47) 
ALOG(¢) 434294481904 x ALOG(¢) 
ASIN(¢) $x ASIN(4)+/(1—-¢7) 
ATAN(¢) @xATAN(}d—LN(14+¢7)/2 
COS(4) SIN(¢) 
1/(COS(#) xSIN(¢)) LN(TAN(¢)) 
COSH(¢) SINH(¢) 
1/(COSH(¢) x SINH(¢)) LN(TANH(¢)) 
1/(COSH(#)?) TANH(¢) 
EXP(¢) EXP(¢) 
EXPM(¢) EXP(¢)—¢ 
LN(¢) oxLN(¢)—6 
LOG(¢) 434294481904 x xX LN(¢)—¢ 
SIGN(¢) ABS(¢) 
SIN(¢) ~COS(¢) 
1/(SIN(¢}xCOS(¢)) LN(TAN(¢)) 
1/(SIN()x TAN(¢)) ~INV(SIN(¢)) 
1/(SIN(¢) x TAN(4)) ~INV(SIN(¢)) 
1/(SIN(¢)?) —INV(TAN(¢)) 
SINH(¢) COSH(¢) 
1/(SINH(¢) x? —INV(SIN(¢)) 
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Symbolic Integration (continued) 


Pattern Antiderivative 
1/(SINH(¢)xCOSH(4)) LN(TANH(¢)) 
1/(SINH($)x TANH(4)) —INV(SINH(¢)) 
SQ(e) $ /3 
TAN(¢)? TAN(¢)-¢ 
TAN(¢) —LN(COS(¢4)) 
TAN(¢)/COS(¢) INV(COS(4)) 
1/TAN(¢) LN(SIN(@)) 
1/TAN(6)xSIN(4)) —INV(SIN(¢)) 
TANH(¢) LN(COSH(¢)) 
TANH(¢)/COSH(¢) INV(COSH(¢)) 
1/TANH(4) LN(SINH(¢)) 
1/TANH(¢)xSINH(¢)) —INV(SINH(¢)) 
Vo 2xd' /3 
i/o 2x So 
1/(2x/(¢)) 2xVS(0)x.5 
$? (2 symbolic) IFTE(2==—1,LN(¢),¢(2+)) /(241)) 
b* (z real, #0,—1) ot) /(241) 
p° $ 
go} LN(¢) 

1/% LN(¢) 
1/0?) ATANH(¢) 
1/(1+4?) ATAN(¢) 
1/(¢+1) ATAN(¢) 
1/(vV(%-1)xv(+1)) ACOSH(¢) 
1//(-¢?) ASIN(¢) 
1/ +?) ASINH(¢) 
1/Jf(¢? +1) ASINH(¢) 
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tatistics and Data Analysis 


Entering Statistical Data 


Data can be accumulated on the HP 48 in two different kinds 

of objects: arrays and lists. In general, lists are best-suited for 
one-variable statistics, arrays for multi-variable statistics. Arrays may 
only contain numerical data; lists may contain any kind of data. 


The built-in STAT application always uses arrays—specifically, it uses 
the data currently stored in the array variable named X DAT. 


However, to apply programmed statistical functions other than those 
built into the STAT application, you may find lists are a more flexible 
object type than arrays. 


To enter statistical data as a list: 


1. Press ()@3) to begin the list. 

2. Type each datum followed by (SPC). Press after you've 
typed the final datum. 

3. Optional: Store the data list in a named variable in order to save 
it for later use. Be careful not to store the list in an HP reserved 
variable, such as EDAT. 


To enter statistical data directly into © DAT: 


LS ae (Actually, you may use any of the STAT 
application input forms.) 

2. Optional: If there is already data in the field either delete 
it (press GE) or save the data by storing it in a variable 
(see next procedure) first and then deleting it. 

3. With the highlight on the field, press 


MatrixWriter (you may need to press first). 


F 


to begin the 


Statistics and Data Analysis 21-1 


21 


21 


ot 


Enter the data. Use a separate row for each individual record and 
a separate column for each variable within a record. For example, 
a data set containing the height, weight, and age for each of 100 
people, would be entered as 100 rows of three columns each. 
Press when you've finished. The data matrix is now 
temporarily stored in / DAT;. To confirm that you want it stored 
there, press 2; to cancel the whole operation, press © : 
to edit it fur ther, press IIT again. 


To store the array in © DAT in a different variable: 


1 


2. Press 


4. 


Press (>)(STAT) OE to open the = ads 


is ; form. (Actually, you may use any of the STAT 
application input forms.) You should see the current statistics 
matrix partially displayed in the ẸpAT: field. 

-> to bring up the stack. 
Enter a name for the matrix onto level 1 (using the ' delimiters), 


and press 


Press. OE to return to the SIHGLE-VARTABLE STATISTIC’. 


To enter statistical data into a matrix: 


1. 
2. 


w 


Press (>)(MATRIX) to begin the Matrix Writer. 

Enter the data. Use a separate row for each individual record and 
a separate column for each variable within a record. For example, 
a data set containing the height, weight, and age for each of 100 
people, would be entered as 100 rows of three columns each. 
Press when you've finished entering the data. 

Enter a name for the data matrix onto level 1 of the stack, and 


press (STO). 


To designate a matrix the current statistics matrix: 


if 


. With the highlight on the E&AT= field, press © 


Press (@)GTAT). OF 


i form. (Actually, you may use any of the STAT 
eee input forms.) 

Optional: If there is already data in the EGAT: field either delete 
it (press OK) or save the data by sine it in a variable 
first and then deleting it. 


bw Bao 


and use the 
arrow keys to highlight the matrix you wish to make the current 
statistics matrix. 
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4. Press (E. to temporarily store the matrix in X DAT. To 
confirm this action, press CHE =: to cancel the action, press 
> You may also use the matrix in the current input form 


before pressing GE or CAREL. 


Example: Enter the following data into a matrix and store it in the 
variable, TEST. Then make TEST the current statistical 
matrix. The data compares the undergraduate grade point 
averages of 12 corporate employees with their scores on a 
managerial trainee examination: 


GPA Exam Score 
2.2 76 

2.4 89 

3.1 83 

2.5 79 

3.5 91 21 
3.6 95 

2.5 82 

2.0 69 

2.2 66 

2.6 75 

2.7 80 

3.3 | 88 


Step 1: Open the MatrixWriter and enter the data (12 rows, 2 
columns) 


(>) GATX) 

2.2 (ENTER) 76 (ENTER) (¥) 

2.4 (ENTER) 89 (ENTER) 3.1 
(ENTER) 83 (ENTER) 2.5 (ENTER) 
79 (ENTER) 3.5 (ENTER) 91 
ENTER) 3.6 (ENTER) 95 (ENTER) 
5 (ENTER) 82 (ENTER) 2.0 
(ENTER) 69 (ENTER) 2.2 (ENTER) 
6 (ENTER 2.6 (ENTER) 75 
(ENTER) 2.7 (ENTER) 80 (ENTER) 
3.3 (ENTER) 88 (ENTER ) ENTER) 


LE f 
c49 
3l 8 
Zd f 


[VECTR HATE] LIST] 


N 


m 
par 


D 
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Step 2: Store the matrix as TEST and open the STAT application. 


C @) (hold) TEST (release) 
MET OE 


SARE SINGLE-VARIAELE STATISTICS Be 
zont: a co: 1 
TYPE: Sample 
_MEAM STO DEY VARIANCE 
TOTAL L MANIMUM _ MINIMUM 


ENTER STATISTICAL DATA 
emy cuon | NcANeL| DK 


Step 3: Choose TEST as the current statistical matrix (X DAT). 


SESE SIMGLE-VARIAELE STATISTICS Se 
zot: (QAM COL: 1 
TYPE: Sample 
_MEAN 9 _STB DEY _ VARIANCE 
_TOTAL 9 _ MAXIMUM _ MINIMUM 


ENTER STATISTICAL DATA 
EDIT [CHOOS| | ANCL] Dk | 


Step 4: The TEST matrix overwrote any data stored in X DAT 
previously. Press Oh. to proceed or AHEL to remove 
TEST and restore the previous contents of X DAT. 


Editing Statistical Data 


To edit an element in the current statistical matrix: 


1. Press (@)(STAT) OF to open the = 


23 form. (Actually, you may use any of the STAT 


application input forms.) 

2. Press -T to bring the current statistical matrix into the 
Matrix Writer. 

3. Use the arrow keys to highlight the element to be changed, type in 
its replacement, and press (ENTER). 

4, Press to save the change and return to the STAT 
application. 


pini 
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To transform a column of the current statistical matrix: 


1. 


. Press TYPES DEJ 


Press (ce)(STAT) tie to open the S1HGLE-VARIAE 
Z TICS form. (Actually, you may use any of the STAT 
a input forms.) 

Press EALE to copy the matrix to the stack. 


Enter the number of the column you wish to transform. 


La cas 


Press E SpoR GL to extract the designated 
column from the matrix. 
Press TYPE GELS (EVAL) LITST to convert the data to 


a list. 

Perform the desired transformation on the data in the list. For 
example, to perform the transformation x’ = 3lnz, press (>) 3 
(x). 


to convert the list to an 


array. 
Enter the column number where the transformed variable is to be 
placed and press HATE COL COLE 

Press ()(CONT) UE — to return to the STAT application with 
the transformed matrix. 


To transform a row, use Fl and RH+: in steps 4 and 8. 


To add a new column to the current statistical matrix: 


1. 


PUO OL e 


Press (@)(STAT) OE to open the SIHGLE-VARTABLE 
STATISTICS form. (Actually, you may use any of the STAT 
application input forms.) 

Highlight the EGAT: field. 

Press ERIT. This opens the MatrixWriter. 

Move the highlight to the location of the new column. 

Press . A column of zeros is inserted. 

Press Gi. You can now replace the zeros with data. 
Press to return the modified matrix to the STAT 
application. 


EFE 


To delete a column of the current statistical matrix: 


. Press (>)(STAT) -GE to open the 51 E-i 


STATISTICS form. (Actually, you may use any of the STAT 
application input forms.) 

Highlight the field. 

Press . This opens the MatrixWriter. 
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4. Move the highlight to the column to be deleted. 
5. Press ={OL. The column is deleted. 
6. Press to return the modified matrix to the STAT 


application. 


To mathematically transform the data in a list: 


1. Put the data list onto the stack. 

2. Perform the arithmetic necessary to transform each datum in the 
list. For example, to perform the transformation, x’ = 3lnx — 4, 
press (¢>)(LN) 3 (x) 4 ©). (Remember to use LIST ADE 
for list element addition instead of ).) 


Calculating Single-Variable Statistics 


If your statistical data measures a sample of a population, you 
calculate sample statistics. If, however, your data measures the entire 
population, you calculate population statistics. 


The single-variable statistics built into the STAT application are: 


MERAH Returns the arithmetic mean of the data in the 
selected column. 
STE BEY Returns the standard deviation of the data in the 


selected column. It computes the version of the 
standard deviation indicated by the TYFE® field 
(sample or population). 
Returns the variance of the data in the selected 
column. It computes the version of the variance 
indicated by the T'FE# field (sample or population). 
Returns the sum of the data in the selected column. 
Returns the value of the largest datum in the 
selected column. 
MIM ITMUM Returns the value of the smallest datum in the 
selected column. 


21-6 Statistics and Data Analysis 


To compute a statistic for one variable: 


. Press ()(GTAT) -58E to open the : 


. Press 


STATISTICS form. 


. Enter or choose the data matrix containing the data for the 


variable. 
Highlight the .§ field and enter the number of the column 
containing the data for the variable. 
Select either € i 


to indicate 


ulation in the T 
which version of the statistic you need to compute. 

Put check-marks in one or more of the statistic check-fields. 

. A labeled result for each statistic is placed on the 


mele or F 


stack. 


To compute a Statistic for all variables in the current data: 


1. 


Press (4)(STAT) -WAE to display the single-variable statistics 
command menu. 


. Press the menu key corresponding to the statistic you wish to 


compute. For example, press MERAH to compute all of the means 
for each of the variables (columns) in the current statistics matrix. 
The result is a vector whose elements are the means of each column 
in the data matrix. 


To compute a median for each variable in the current data: 


1. 


Type TEACH and press to place a copy of the built-in 
EXAMPLES directory in the HOME directory. 


. Press EXAM FROGS HEDEN. The result is a vector 


containing the medians for each variable (column) in the current 
statistics matrix. 


To draw a bar plot of the data for a variable 


1. 


grer y eT 


Use the : YARILABLE STATISTICS form to select the 
current statistics matrix and the column in that matrix containing 
the data you wish to plot. 


. Press ME to accept the choices and return to the stack. 
. Press (&) (STAT) FLOT- BAREL to draw the bar plot using 


autoscaling (see 23-19 for more details.). 
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Generating Frequencies 


Many times, the most meaningful aspect of a data set is its 
distribution. Frequencies and frequency distributions are a common 
method for analyzing the distribution of a set of data. 


Frequencies are created by dividing an interval (often that between the 
largest datum and the smallest) into an arbitrary number of equal 
subintervals, or bins, the number of which is suggested by the data 
and the precision with which one wants to study the distribution. The 
diagram below illustrates this. 


21 oe & sy 
A A N N 5% | 


x\ 
| 15 21, 47 53 Pi 97 
| 149 | 39 | 5055| 71 | 100 


0 20 40 60 80 100 


To convert a data set into a set of frequencies: 
1. Press ()GTAT)(¥) GE to open the FREQUENCIES form. 


#-MIH: -6.5 
EIN COUNT: 13 BIN HIDTH: 1 


ENTER STATISTICAL DATA 
EMT [CHOD] [L anel Ok | 


The FREQUENCIES Screen 


2. Enter or choose the data matrix containing the data into the 
ECAT: field. 


21-8 Statistics and Data Analysis 


3. Enter the column number where the data to be converted is 
located. 

4. Highlight the + i: field and enter the minimum value that a 
datum can be and still be considered to lie within a bin. All lower 
values are considered outliers. 


5. Enter the number of bins to use into the field. 

6. Enter the width of each bin into the ! field. All bins 
are of equal width. 

7. Press to perform the conversion. On level 2 of the stack, 


you will see an array with integer elements, each one representing 
the number of data points that fell into each bin (in order 

from lowest to highest). On level 1 of the stack, you will see a 
two-element. vector displaying the number of outliers. The first 
element represents the outliers below the lowest bin, and the second 
element represents the outliers above the highest bin. 


To plot a histogram using the frequencies: 


1. Convert the data set into frequencies as in the previous procedure. 

2. Press to delete the outlier vector. 

3. Press (4)(STAT) CATA (4) EGAT. to store the frequency data in 
DAT. 

4. Press (@)(STAT) FLOT E 


Fi to plot the frequencies. 


The HP 48 can use any of four general regression models in the 
attempt to quantify the relationship between the data in two columns 
from the current statistical matrix (Y DAT): 


y=b+mzr 
y=b+mlnz 


„ME 


y = be” or lny = lnb + me 


y =b” or hny =lnb+ mln 


For each of these general models the regression tool will find an 
intercept (b) and a slope (m) that corresponds to the least-squares fit 
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for that model. It also computes and returns the covariance (sample 
or population) and the correlation coefficient for the regression. 


To perform a regression for two variables in the current data: 


L. Press ()GTAD W) M 


bo 


5. 


#-c0L: 


i 


ENTER STATISTICAL DATA 
EDIT [cHOOS| | PRED [CAMEL] DK | 


The FIT DATA Screen 


¥-cOL: 2 
MOEL: Linear Fit 


to open the FIT DATA form. 


Enter or choose the data matrix containing the data you wish to fit. 


Enter the independent variable in 


variable in ‘Y-OL:. 


“~fOL: and the dependent 


Choose one of the four regression models (or Best Fit, which 
automatically selects the model with the correlation coefficient with 
the largest absolute value). 
Press UE . You will see the computed regression model on 
level 3, the correlation coefficient on level 2, and the covariance on 


level 1. 


To use the computed regression to predict the value of a variable: 


l. 


Press @GTAD W W) 


HE 


to open the F 


oon an 


ra form. 


2. Enter or choose the data matrix containing ‘he data you wish to fit. 


3. 


4. Choose one of the four regression models (or Ẹ 


PS 
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Enter the independent variable in 


variable in *f—-COL:. 


HoCOLe and the dependent 


p 


Fit, which 


automatically selects the model with the coirelation coefficient with 


the largest absolute value. 
. Press i to display the PREDICT 


Enter the assumed value in either the #: or the 


form. 


‘= field. 


Move the highlight, if necessary, to the variable field whose value 


you wish to predict, and press FRE 


©. The computed value is now 


displayed in the field. Press ERIT to view the complete number. 


To plot a scatterplot of the data and the regression curve: 


1. Perform the Hees as described above. 

2. Press ()(STAT) PLOT SCATE to plot the data using 
auto-scaling (see page 23-20 for details). 

3. After the plot is drawn, press STETI to superimpose the most 
recent regression model on top of the data. 


Calculating Summary Statistics 
There are six summary statistics available that you may use to analyze 


statistical peculiarities within a data set or to compute statistics other 
than those built into the STAT application. 


SUMMARY STATISTIC 21 
EDAT: 
H-COL: j ¥-COL: 2 
CALCULATE: 

-Z LEY ZKR EYE 


ENTER STATISTICAL DATA 
[EuT jcnon) O d fenNeL | oE] 


The SUMMARY STATISTICS Screen 


-Ey _WE 


The six summary statistics are: 


EX Sum of the data in the * of XY DAT. 

LY Sum of the data in the ¥~1 of DAT. 

UX2 Sum of the squares of the data in the ¥ 
SDAT. 

NY2 Sum of the squares of the data in the * 
SDAT. 

XXY 
y Si EDAT. 

NE a, ae rows in DAT. 


To compute a summary statistic: 


1. Press (->)(STAT) @) GE — to display the 


form. 


Statistics and Data Analysis 21-11 


2. Enter or choose the data matrix containing the data with which 
you are computing. 

3. Enter the column numbers of the independent (* 
dependent (*-ffH 


ii.) and 


iL.) variables. 

4. Put a check-mark in each summary statistic that you wish to 
compute. 

Press © GE. Labeled results are placed on the stack. 


font 


Using the SPAR Reserved Variable 


The HP 48 uses a built-in statistics parameter variable named X PAR 
to store the statistics parameters. Y PAR contains a list with the 
following objects: 


£ independent-col dependent-col intercept slope model > 


To view the current settings in UPAR: 


a Do one of the following: 
o Press @)GTAT) ZFAR IMFO. The default settings are shown 
below. 


Intercept: & 


Slope: 
Model: LINFIT 
[acot | YcOL [POOL EPAR [RESET INED | 


o Press (4,)(STAT) = 
The default list is = 


You normally control the parameters automatically using the STAT 
application. Because J PAR is a variable, you can have a different 
X PAR in every directory. 
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Using the PLOT Application 


The PLOT application lets you draw graphs of one or more functions 
in various formats, calculate roots and other parameters, plot 
statistical data in various formats, and embellish plots with additional 
elements. 


The HP 48 can plot an equation, expression, or, for some plot types, a 
program: 


m Equation. An equation is an algebraic object containing = (for 
example, 'R+E=(2'), 


m Expression. An expression is an algebraic object not containing = 
(for example, 'FA+E'). 


a Program. A program to be plotted must return one real number (or 
a complex number for PARAMETRIC plots). 


Throughout this chapter, unless otherwise stated, the term “equation” 
refers to all objects used to create plots: equations, expressions, 
programs, and lists of equations, expressions, and programs. 


Plots are always drawn on the graphics object currently stored in the 
reserved variable PICT. To view the “picture” currently stored in 


PICT, you may press (4) (PICTURE). 


To plot a single expression: 
1. Press ()(PLOT) to open the PLOT application. You will the see 


the main PLOT screen showing the current plot type in TYPE: and 
the current equation in Ef: (if any). (The three statistical plot 
types (Scatter, Bar, and Histogram) use the = 2 field instead of 
the Ets.) 


Plotting 22-1 


22 


THRE: Function j d: De 
EG: 
INDEF: 3 H-YEW: -6,5 6.5 


_AUTOSCALE V-VIEH: -3,1 3.2 


ENTER FUNCTIOM(S) TO PLOT 
EMT [cions] [OPTA] 


The Default PLOT Screen 


2. If necessary, press (A) and change the plot type, by doing any one of 
the following: 
a Press repeatedly until the desired choice appears in the field. 
m Press © :, highlight the desired choice in the choose list and 


press EO. 

a Press (œ) followed by the first letter of the desired choice. You 
may need to repeat this step one or more times for plot types 
that share the same starting letter with others (e.g. Polar, 
Parametric, Pr-Surface, Ps-Contour). 

3. Enter new values (or accept the current values) for the various 
plotting parameters available for the selected plot type. Chapter 
23, “Plot Types,” discusses each of the 15 available plot types and 
the plotting parameters and display options in greater detail. Most 
plot types have a second screen, accessed by pressing OF TS that 
contains display options for the plot type. 

4. Once all values, parameters, and options have been set, do one of 
the following: 

m Press ERASE GRAM to “erase” PICT of any picture it 
contained previously and draw the plot according to the 
specifications you’ve set. You will see the plot being drawn and 
have access to it after the drawing is complete. Chapter 22, 
“Plotting” discusses the kinds of analysis and embellishments you 
can do to a plot after it has been drawn. 

m Press GRAH. to draw the plot superimposed on the previous 
picture in PICT. 

m Press CE to save the settings and options and return 
to the stack without drawing the plot. 

a Press CAMEL (or (CANCL)) to restore the settings and 
options in place before you made any changes and return to the 
stack without drawing the plot. 


22-2 Plotting 


To plot a single equation: 


1. Use the same general procedure as for plotting an expression, 
but make note of the following differences when the plot type is 


Furet 


m For equations whose left-hand side consists only of the name of 
the dependent variable (such as y = 4x? — 7x + 29), only the 
right-hand side expression is plotted. 

m For equations whose left-hand side consists of some expression 
other than the name of the dependent variable (such as 
sin x = cos x), the left-hand and right-hand expressions are both 
plotted. 


To plot a group of expressions or equations: 


1. Press ()(PLOT) to open the PLOT application. 
2. Do one of the following to enter a list of the expressions or 
equations into the Et: field. 

m If all of the expressions or equations are stored in variables, press 
CHOOSE, move the arrow keys to highlight each expression or 
equation in turn, and press THE to select it. Return a list of 
all checked equations to ER: by pressing. GE 

a Type (4)(3) to begin a list and then type each expression or 
equation in as an element of the list. Press to enter the 
list into Elis. 

m Combine the previous two approaches by selecting those 
expressions and equations that are stored in variables into a list 


using CHOOS, entering it into Efs, and then editing the list 
using EẸIT . You may add, insert or modify equations in the 
list. 


Note that each expression or equation in the group must be 
appropriate for the given plot type (see chapter 23 for details). 
Also, when equations (containing the = sign) are included in a list 
to be plotted using the Funct iar plot type, only the right-hand 
side expressions of each equation is plotted. The left-hand side 
expressions are ignored. You may wish to rearrange some equations 
so that they are expressions (or equations whose left-hand side is 
zero). 

3. Enter values for the plotting parameters and display options, if 
necessary. 
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4. For Function, Polar, and Parametric plot types, put a check-mark 
in the SIMULT field (on the FLOT GFTIOHS screen) if you want 
the plots of all expressions and equations in the list to be drawn 
simultaneously. If this field is left unchecked, then the plots will be 
drawn sequentially (as they always are for other plot types). 

5. Press ERASE DRAM. (or just GRAM if you don’t want to erase 
the previous plot or picture). 


Cursor Coordinates: Standard and TRACE 
Modes 


To display the current cursor coordinates: 


æ While viewing the plot, press {4% to hide the menu and display 
the coordinate values (in user-units) of the current cursor position. 
Press to redisplay the menu and cancel the coordinates 
display. 


Whenever a plot is drawn—either originally or as a part of a zoom 
operation—the cursor begins in standard graphics mode. In standard 
mode, pressing (€), Œ), (A), or (F) causes the cursor to move in the 
indicated direction without regard to the current plot. In standard 
mode, the horizontal and vertical “centers” of the pixel currently 

at the intersection of the crosshairs are reported as the current 
coordinates. 


Some plot types also offer TRACE mode as an alternative mode of 
cursor movement. In TRACE mode, the cursor jumps from plotted 
point to plotted point along the function, instead of along pixel rows 
and columns. TEH(CE will appear in the menu if the current plot type 
uses TRACE mode. 


To turn TRACE mode on and off: 


æ While viewing the plot, press TRACE to turn on TRACE mode. 
The æ is displayed in the menu label whenever TRACE is on. Press 
TRAC to turn off TRACE mode. Note that executing a zoom or 
other function that redraws the graph will automatically turn off 
TRACE mode, as well. 
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For F F “ic plot types, TRACE mode 
redefines the arrow betas (<<) and (>) move the cursor backwards and 
forwards along the plot of the current equation. If multiple functions 
are plotted, then (A) and (F) “jump” the cursor between the different 
functions. You may press + while TRACE mode is on in order 


to display the coordinates of pomts on the graph. 


fu 


ram 


Keyboard Operations ir in the PICTURE 
Environment 


The PICTURE environment redefines the keyboard so that only a few 
keys are active. Those that are active are described in the table below: 


Key Description 


D — 
Menu Keys | Behave as they always do—executing the operation 
indicated in the corresponding menu label. 


NXT Displays the next menu page. 
(<4) (©) (4) (¥) | Move the cursor in the indicated direction. When 
TRACE mode is on, the cursor movement is 
constrained according to the content and type of plot 
(see chapter 23 for more details). 
(#)(PICTURE) | Toggles the scrolling mode on and off. Scrolling 
mode hides the menu and the cursor and, if PICT is 
larger than the display allows you to scroll around 
using the cursor keys. 


(D (CLEAR Erase the picture. It is a shortcut for 


(4) (VIEW) Displays the current equation while the key is held 
down. If TRACE mode is on, it displays the function 
which is currently being traced. 


Plotting 22-5 


22 | 


Key Description 
Erases the rectangular region defined by the cursor 
and the mark. It is a shortcut for ERIT (NXT 
DEL 
Places a copy of the current picture on the stack as a 
graphi T: (NXT 
NXT}: 
Enters the current coordinates of the cursor onto the 
stack as a complex number. It is a shortcut for 
Returns to the display from which the PICTURE 


+ = 


environment was entered. 

Sets the mark at the current location of the cursor. 
It is a shortcut for ERIT (NXT ¿i The mark 
is used to delineate one endpoint of a range. After 
setting a mark, the cursor may then move and 
delineate the other endpoint. 


Toggles the menu labels off and on, showing that 
portion of the plot that is hidden by the labels. It is 
a shortcut for ED TT MEHL. 

Toggles the cursor coordinates display on and off. It 
is the same as {3 73. 

Switches the cursor appearance. The cursor is either 
always dark (default) or is dark against a light 
background and light against a dark background. 


The zoom operations in the PICTURE environment let you look at a 
particular region of the plot in more detail (by zooming in) or look at 
more of the plot than is currently displayed (by zooming out). 


A zoom, or zoom operation, redraws the current plot by computing 
new display parameters. Zooms are a shortcut for the process of 
returning to the PLOT application, changing the values of the display 
parameters, and redrawing the plot. Note that not all plot types make 


use of zoom. 
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Setting Zoom Defaults 


Several of the zoom operations make use of the current zoom factor 
and recenter option settings, which you can control. 


To set the zoom factors: 


1. Press “200 2FACT to open the 2! 


TYPE: Polar 
EQ: 
INDEP: W H-HIEH: -6.5 6.5 


—AUTOSCALE Y-VEH: -3.1 3.2 


ENTER FUNCTION(S) TO PLOT 
EMIT [coos] | OPTA [ERASE] DRAH] 


The ZOOM FACTORS Screen 


ates shed : . 22 
2. Enter the multiplicative factors for the horizontal and vertical axes 


that you want Zoom In and Zoom Out (and a few other zooms) to 
use. Note that Zoom Out multiplies the scale by the factor while 
Zoom In divides the scale by the factor. 

3. Set the recenter option that you want zooms to use. Leaving the 
RECEHTER AT CROSSHAIRS field unchecked causes the after-zoom 
display to be centered at the same point as the before-zoom display. 
Putting a check-mark in the field causes the after-zoom display 
to be centered around the point where the crosshairs cursor was 
located when the zoom was executed. 

4. Press 


Selecting a Zoom 


To perform a zoom: 


1. While viewing the plot, move the cursor to the desired spot (if 
necessary for the zoom you wish to use), and press 200M . 
2. Select the zoom you want (see below for details about each). 


Zoom-to-Box. Allows you to draw a box around 
the region of interest and then zoom so that the 
boxed-in region fills the display. Move the cursor to 
one corner of the region before selecting this zoom. 
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Zoom-In. Decreases both horizontal and vertical 
scales by the current zoom factors. 

Zoom-Out. Increases both horizontal and vertical 
scales by the current zoom factors. 

Zoom-to-Square. Changes the vertical scale so that 
it matches the horizontal scale. 

Zoom-to-Default. Redisplays the plot using the 
built-in default display ranges. Ignores the recenter 
option. 

Horizontal Zoom-In. Decreases the horizontal scale 
by the current zoom factor without affecting the 
vertical scale. 

Horizontal Zoom-Out. Increases the horizontal scale 
by the current zoom factor without affecting the 
vertical scale. 

Vertical Zoom-In. Decreases the vertical scale by the 
current zoom factor without affecting the horizontal 
scale. 

Vertical Zoom-Out. Increases the vertical scale by 
the current factor without affecting the horizontal 
scale. 

Recenter-on-Cursor. Redisplays the plot around 
the point where the crosshairs cursor was located 
when EHTE is pressed. Overrides default recenter 
option. 

Autoscale Zoom. Rescales the vertical axis using the 
built-in autoscaling computation without affecting 
the horizontal scale. 

Decimal Zoom. Rescales the horizontal axis so that 
each pixel equals exactly 0.1 units. Does not affect 
the vertical axis. 

Integer Zoom. Rescales the horizontal axis so that 
each pixel equals exactly 1 unit. Does not affect the 
vertical axis. 

Trigonometric Zoom. Rescales the horizontal axis 
so that 10 pixels equals 5 units and rescales the 
vertical axis so that every 10 pixels equals one unit. 
Zoom-to-Last. Redraws the display as it was prior to 
the most recent zoom. Ignores the recenter option. 


Analyzing Functions 


The PICTURE FCN menu lets you analyze the mathematical 
behavior of plotted functions. You use the graphics cursor to indicate 
the region or point of interest on the graph, then execute the desired 
calculation from the menu. You can calculate function values, slopes, 
areas under curves, roots, extrema and other critical points, and 
intersections of two curves. You can also plot derivatives of plotted 
functions. 


To do function analysis, the current plot type must be Funet ian. 
In addition, EQ must contain an equation, expression, or a list of 
equations or expressions—it cannot contain a program. 


If EQ is a list of expressions, FCN menu operations use only the first 
(or first and second) element(s) of the list. The : operation is 

used to rotate the elements of the list so that different expressions are 
“first” and “second.” 


To analyze a plotted function: 


1. While viewing the plot, press FH 

2. Press (A) (F) (4) (>) to move the cursor to the point you want to 
analyze. (For certain operations, the cursor merely needs to be near 
the point.) 

3. Press the menu key for the function analysis operation you want. 
See the table below. 

4. Press FEET. (in the second page of the FCN menu) to return to 
the main PICTURE menu. 


When you perform a function analysis operation, the HP 48 does the 
following: 


a Moves the cursor to the corresponding point on the function (if that 
point is in the display). 

m Displays a message in the lower-left corner of the display showing 
the result. 

m Returns the result to the stack as a tagged object. 
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The PICTURE FCN Menu 


Description 


in the PICTURE menu): 


SLOPE 


RARER 


Root. Moves the cursor to a root (intersection of the 
function and the z-axis) and displays the value of the 
root. If the root is not in the display window, briefly 
displays the message (FF SCE before displaying 
the value of the root. If there are multiple roots, the 
root-finder usually finds the root closest to the current 
cursor location. For an equation, it searches for a root 
of the expression on the right side of the equation. 


Intersection. If only one function is plotted, moves the 
cursor to a root (same as FOOT ). If two or more 
functions are plotted, moves the cursor to the closest 
intersection of two functions and displays the (z,y) 
coordinates. If the closest intersection is not in the 
display window, briefly displays the message {FF 
SCREEN before displaying the coordinates of the 
intersection. 

Slope. Calculates and displays the slope of the function 
at the r-value of the cursor, and moves the cursor to 
the point on the function where the slope was 
calculated. 

Area. Calculates and displays the area beneath the 
curve between two z-values defined by the mark and 
cursor. (Before you execute this operation, press (x) to 
mark one end of the z interval, then move the cursor 
to the other end.) 

Shade. If only one function is plotted, shades the 
region between the z-values defined by the mark and 
the cursor, between the function and the z-axis. If 
there are two functions plotted, shades the region 
between the two functions, and between the z-values 
defined by the mark and the cursor. 
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The PICTURE FCN Menu (continued) 


Description 


TAHE 


premia 


Extremum. Moves the cursor to an extremum (local 
minimum or maximum) or other critical point and 
displays the (z,y) coordinates. If the closest extremum 
or inflection point is not in the display window, briefly 
displays the message OFF SC before displaying 


the value. 


Function Value. Displays the function value at the 
current x-value of the cursor, and moves the cursor to 
that point on the function curve. 

Derivative Plot. Plots the first derivative of the 
function and replots the original function. Also adds 
the symbolic expression for the first derivative to the 
contents of EQ. (If EQ is a list, F’ adds the expression 
to the front of the list. If FQ is not a list, F' creates a 
list and inserts the expression to the front of the list.) 
Tangent Line. Draws the line tangent to the current 
function at the z-value represented by the cursor. It 
returns the equation of the tangent line to the stack. 
Next Equation. Rotates the list in EQ and displays 
the equation now at the beginning of the list. (The 
second equation is moved to the beginning of the list 
and the first equation is moved to the end.) 

View Equation. Displays currently selected equation 
from EQ or EQ list. 

Picture. Displays the PICTURE menu. 


Plotting 22-11 


22 


22 


The PLOT application makes it easy to declare the plot and display 
ranges, the scale and resolution of the plots, and various other 
characteristics of the plot. 


All of the information about a plot is automatically stored in a small 
set of reserved variables that you have direct access to if you wish. 
Because they are variables, stored in directories, you can have a 
different version of these reserved variables in every directory. 


EQ 


EQ contains the current equation or the name of the variable 
containing the current equation. 


Specifically, the “equation” that EQ contains can be any of the 
following for the PLOT application: 


æ A single algebraic object or a name containing a single algebraic. 

m A real number (or a complex number for the Parametric plot type) 
or a name containing a real number. 

m A program that takes nothing from the stack and yields exactly one 
real (or complex for the Parametric plot type) result or a name 
containing such a program. 

m A list containing any combination of the preceding three possibilities 
or the name of such a list. Although all elements are plotted, the 
first element of the list is always considered to be the “current” 
equation. 


EDAT 


X DAT contains the current statistical matrix or the name of the 
current statistical matrix. It is used instead of EQ by the three 
statistical plot types—Scatter, Bar, and Histogram. 
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ZPAR 


ZPAR stores zoom information: the horizontal and vertical scale 
factors, a recenter flag, and (sometimes) a copy of PPAR to be used 
by the Zoom-to-Last (ZLA=T) operation. ZPAR contains a list with 


the following objects: 


h-factor v-factor center-flag È previous PPAR (if any) > 


PPAR 


The HP 48 uses a built-in plot parameter variable named PPAR 
to store the plotting parameters. You normally control the plot 
parameters using commands in the FLET and } P 

PPAR contains a list with the following objects: 


E Imin: Ymin? “Tmax: Ymax” indep res ares ptype depend % 
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Contents of the PPAR List 


Element 


Description 


Default 


(Emin ; Ymin) 


(Tmax Ymax) 


indep 


res 


axes 


plype 
depend 


A complex number representing the 
coordinates of the lower left corner of 
the display range. 

A complex number representing the 
coordinates of the upper right corner of 
the display range. 

Independent variable. The name of the 
variable, or a list containing the name 
and two real numbers (the horizontal 
plotting range). 

Resolution. For equations, a real number 
or binary integer representing the 
interval between plotted points. For 
statistical data, the meaning varies. 

A complex number representing the 
coordinates of the axes intersection, or a 
list containing the intersection and labels 
(strings) for both axes. The Diff Eq plot 
type uses this element in a special way 
(see page 23-11). This element can also 
contain information about the 
tick-spacing for each axis. 

Command name specifying the plot type. 
Dependent variable. The name of the 
variable, or a list containing the name 
and two real numbers (the vertical 
plotting range). The Diff Eq plot type 
uses this element in a special way (see 
chapter 23). 


(—6.5,—3.1) 


X 


0 (points 
plotted in 
every pixel 
column) 


(0,0) 


FUNCTION 
Y 


To reset PPAR to its default: 


a Press (JED ! 


F operation resets all 


parameters in PPAR tS thee default e the plot type— 
and erases PICT and restores it to its default size. 
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VPAR 


VPAR contains the current settings that determine the View Volume, 
eyepoint, and plotting density for the six plot types for functions 
of two variables. See page 23-22 for a full explanation of how its 
parameters relate to the plot display. 


VPAR is a list of real numbers: 


Z Xiete X right Ynear Ytar Ziow Zhigh XX left XX right YY left YY right 
X eyept Y eyept Z eyept Nx Ny } 


Contents of the VPAR List 


Element Description Default 
X left The smallest output (View Volume) -1 
value for the z-axis (width) to be 
plotted. 
X right The largest output (View Volume) value 1 
` [for the x-axis (width) to be plotted. 
Yes The smallest output (View Volume) -1 
value for the y-axis (depth) to be 
plotted. 
Y far The largest output (View Volume) value 1 
for the y-axis (depth) to be plotted. 
Ziow The smallest output (View Volume) -1 
value for the z-axis (height) to be 
plotted. 
Zhigh The largest output (View Volume) value 1 
for the z-axis (height) to be plotted. 
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Contents of the VPAR List (continued) 


Element Description Default 
XX left The smallest value for the horizontal -1 
axis of the input plane. 
XX right The largest value for the horizontal axis 1 
of the input plane. 
YY left The smallest value for the vertical axis <1 
of the input plane. 
YY night The largest value for the vertical axis of 1 
the input plane. 
Neyept The x-axis coordinate for the eyepoint. 0 
Yerept The y-axis coordinate for the eyepoint. -3 


It must always be at least one less than 
the Y near value. 
Z eyept The z-axis coordinate for the eyepoint. 0 


Nx The number of columns in the plotted 10 
lattice. Used instead of or in 
combination with the res element of 
PPAR. 

Ny The number of rows in the plotted 8 
lattice. Used instead of or in 
combination with the res element of 
PPAR. 


PAR 


X PAR is used in conjunction with Y DAT by the statistics plot types. 
It contains either the current statistical parameter list or the name of 
the variable containing this list. See page 21-12 for an explanation of 
this reserved variable. 
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lot Types 


Function Plots 


The Function plot type plots equations that return a unique f(x) for 
each value of x. It is the default plot type and the only plot type that 
can use the PICTURE FCN analysis tools (see chapter 22). 


The Default FUNCTION Plot Screens 


PLOT OPTIONS 
INDEP: Ba Lo: DF Lt HE 
WARES CONNECT SIMULT 
STEP: DF Lt PIXELS 

H-TICK: 10 V-Tick: 16 wt PIKELS 


ENTER INDEPENDENT VAR MAME 
pemr a T dane ok 


THRE: Function á: De 
EG: 

INDEP: W H-MEH: -6,.5 6.0 
_AUTOSCALE Y-VIEM: -3,1 3.2 


ENTER FUMCTION(S) TO PLOT 
[Emt (choos | OPTS ERASE] ORAL] 


The Function PLOT Form 


ae Shows the current angle mode, Change it by pressing 

one or more times or by using GHOOS. 

Enter the current expression, equation, or program 

to be plotted. It may contain a list of expressions, 

equations, or programs if you are plotting multiple 

functions. Names of variables containing expressions, 

equations, or programs (or lists of these) may be used 

in place of the objects themselves. 

Enter the name of the independent variable. 

Enter the horizontal display range in the two fields, 

low endpoint in the left and high endpoint in the 

right. To enter computed endpoints, use 

CALE (see page 24-6). 

Me TER: Enter the vertical display range in the two fields, low 
endpoint in the left and high endpoint in the right. 
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To enter computed endpoints, use ce 
page 24-6). 

When checked the vertical display range is 
automatically scaled based on sampling 40 values 
equally spaced across the horizontal display range. 
When left unchecked the vertical display range is 
determined by the values entered in the two fields 
labeled 4 id. 
Opens the PLOT OPTIONS form. 

Erases the PICT screen (without displaying it). 
Stores all of the values in their appropriate places in 
the reserved variables, FQ and PPAR, and draws 
the plot accordingly, leaving you in the PICTURE 
environment when finished. 


(see 


The Function PLOT OPTIONS Form 


THOEP 


Lil 


HI: 
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Enter the name of the independent variable, if 
necessary. 

Enter the smallest value of the independent variable 
that you want plotted. Plotting range can be 
different than display range (see page 24-3). To use 
a computed endpoint, use CALI (see page 
24-6). 

Enter the largest value of the independent. variable 
that you want plotted. Plotting range can be 
different than display range (see page 24-3). To use 
a computed endpoint, use CALE (see page 
24-6). 

When checked (default), the coordinate axes are 
drawn along with the plot. When unchecked, the axes 
are not drawn. 

When checked (default), the plotted points are 
connected by short line segments. When unchecked, 
only the plotted points are displayed. 

When checked, multiple functions are plotted 
simultaneousl function 
at a given sample value before moving to the next 
sample value. When unchecked (default), multiple 
functions are plotted sequentially—all points are 
plotted for the first function before the first point is 
plotted for the second function, and so forth. 


This determines the resolution of the plot. It is the 
horizontal distance (in units or pixels—see next 

field) between two plotted points. Larger step-sizes 
provide speedier plots, but show less detail, while 
smaller step-sizes provide more detail, but take longer 
to draw. The default step-size for F Lon is 0.1 
units. 

When checked, the step-size is interpreted to represent 
pixels. When unchecked (default) the step-size is 
interpreted to represent units. 

H-TICE Enter the tick-spacing that you want displayed on the 
horizontal axis. It can be determined either in pixels 


or units depending on the state of its F 
(see below). The default is one tick-mark every 10 
pixels. 
We IDE Enter the tick-spacing that you want displayed on the 
vertical axis. It can be determined either in pixels or 
units depending on the state of its FIELS field (see 23 
below). The default is one tick-mark every 10 pixels. 
FISELS When checked (default), the tick-spacing in H~TICE 
and -TICE is interpreted to represent pixels. When 
unchecked, the tick-spacing is interpreted to represent 
units. 


TRACE Mode 


m (4) and (>) move the cursor along the plot of the current function. 
m (A) and (F) jump the cursor between functions when multiple 
functions are plotted. 


Special Notes 


w Algebraic expressions in Ef! may contain any number of variables. 
However, all variables except the independent variable must evaluate 
to a real number in order for Ef! to be plotted. Otherwise, you will 
get the Unde? 


“a error message. 


Example: Display the function example plot, XSIN: z + sin x. If 
necessary, type in TEFH to install the EXAMPLES 
directory and then: 
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Press E 


[20u [ckt [TRACE] FCM | EDIT [CANEL] 


After plotting, press (CANCEL) ({>)(FLOT) to review the PLOT forms 
that generated the plot. Experiment by changing values or settings 
and redrawing the plot. 


Polar Plots 


The Polar plot type plots functions described according to the polar 
coordinate system f(@). The independent variable is the polar angle, 


0. 


The Default POLAR Plot Screens 


se PLOT OPTIONS 
INDEF: Lo: & : 8 
wf AES Z CONNECT SIMULT 
STEP: DEl _PIKELS 

H-TICK: J V-TICK: 1@ f PIRELS 


ENTER INDEPENDENT YAR MAME 
EDIT] | | ANCL Ok | 


INDEP: a H-VEW: -6.5 6.5 
—AUTOSCALE V-VEH: -3,1 3,2 


ENTER FUNCTIONCS) TO PLOT 
EMT (chons) | OPT: [ERASE] DRAH] 


The Polar PLOT Form 


Shows the current angle mode. C pee it by pressing 
one or more times or by using £ A 
Enter the expression, equation, or program nite be 
plotted. 

Enter the name of the independent variable. Note 
that the commonly used polar variable, 8, is entered 
by pressing @)(Q)F. 

Enter the horizontal display range in the two fields, 
low endpoint in the left and high endpoint in the 
right. 
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Enter the vertical display range in the two fields, low 
endpoint in the left and high endpoint in the right. 
When checked the vertical display range is 
automatically scaled based on sampling 40 values 
equally spaced across the horizontal display range. 
Note that because the HP 48 computes an appropriate 
z- and y-axis display range based on the @-range, the 
resulting r- and y-axis scales may differ from one 
another. When this field is left unchecked the vertical 
display range is determined by the values entered in 
the two fields labeled ¥ : 

Opens the PLOT OPTIONS form. 

Erases the PICT screen (without displaying it). 
Stores all of the values in their appropriate places in 
the reserved variables, EQ and PPAR, and draws 

the plot accordingly, leaving you in the PICTURE 
environment when finished. 


The Polar PLOT OPTIONS Form 


THDR: 
LO: 


HI: 


Enter the name of the independent variable. 

Enter the smallest value of the independent variable 
that you want plotted. For Polar plots, the plotting 
range is different than display range. 

Enter the largest value of the independent. variable 
that you want plotted. Plotting range is always 
different than display range for polar plots because 
the independent variable is distinct from the 
horizontal-axis variable. 

See the Function plot type. 

See the Function plot type. 

See the Function plot type. 

This determines the resolution of the plot. It is the 
interval between two plotted points. The default 
step-size for Flair is 2 degrees or 7/90 radians. 
Leave unchecked for polar plots. 

See the Function plot type. 


See the Function plot type. 
See the Function plot type. 
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TRACE Mode 


m (<) and (>) move the cursor along the plot of the current function. 
(4) moves the cursor to the next lower value of the independent 
variable and (>) moves the cursor to the next higher value of the 
independent variable. This may result in directional movement 
counter to the “direction” implied by the arrow keys. A polar plot 
can be traced through the range 8 > 0, so you will be able to press 
(®) indefinitely in TRACE mode, even beyond the plotted interval. 

a (A) and (F) jump the cursor between polar functions when multiple 
functions are plotted. 


Special Notes 


m Unless you specify otherwise, polar plots are drawn for a full circle 
of the independent variable @ (0 through 360 degrees, 27 radians, or 
400 grads, according to the current angle mode). 


Example: Display the polar example plot, ROSE: r = 2cos4é. If 
necessary, type in TEACH to install the EXAMPLES 
directory and then: 


Press ESATE PLOTS 


pi 


i 


(zonta ftsvi [TRACE] | EDIT 


After plotting, press (CANCEL) (@)(PLOT) to review the PLOT forms 
that generated the plot. Experiment by changing values or settings 
and redrawing the plot. 
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Parametric Plots 


The Default PARAMETRIC Plot Screens 


LOT Th WETS = PLOT OPTIONS 

TYPE: Parametric s: De INDER: BM Lo: Delt owe DP At 
Ets: Ee 
INDEP: $ 


Z ARES x CONNECT  _ SIMULT 


H-HIEM: -6. D 6.5 STEP: DF 14 _ PIKELS 


_AUTOSCALE Y-¥IERE -3,1 3.2 H-TICK: 10 o¥-TICK: Joy PIRELS 
ENTER COMPLEX-VALUED FUNC(S3 ENTER INDEPENDENT VAR MAME 


EMT [cHOOS] | 


[OPTS [ERASE] DRAH] EMT) Jo J ee 


The Parametric PLOT Form 


Shows the current angle mode. eee it by pressing 
(+/-) one or more times or by using € : 
Enter the expression, equation, or program te be 
plotted. The Parametric plot type requires that a 
complex number result be returned when EQ is 
evaluated (see Special Notes below). EQ may contain 
a list of expressions, equations, or programs if you 
are plotting multiple functions. Names of variables 
containing expressions, equations, or programs (or 
lists of these) may be used in place of the objects 
themselves. 
Enter the name of the independent variable 
(commonly 7). 
Enter the horizontal display range in the two fields, 
low endpoint in the left and high endpoint in the 
right. 
Enter the vertical display range in the two fields, low 
endpoint in the left and high endpoint in the right. 
When checked the vertical display range is 
automatically scaled based on sampling 40 values 
equally spaced across the horizontal display range. 
When left unchecked the vertical display range is 
determined by the values entered in the two fields 
labeled Y-Y IEH. 
Opens the PLOT OPTIONS form. 
Erases the PICT screen (without displaying it). 
Stores all of the values in their appropriate places in 
the reserved variables, EQ and PPAR, and draws 
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The Parametric 


PISELS 


TRACE Mode 


the plot accordingly, leaving you in the PICTURE 
environment when finished. 


PLOT OPTIONS Form 


Enter the name of the independent variable. 

Enter the smallest value of the independent. variable 
that you want plotted. Plotting range for Parametric 
plots are usually different than display range (see page 
24-3). 

Enter the largest value of the independent variable 
that you want plotted. Plotting range can be different 
than display range (see page 24-3). 

See the Function plot type. 

See the Function plot type. 

See the Function plot type. 

This determines the resolution of the plot. It is the 
horizontal distance (in units or pixels—see next field) 
between two plotted points. The default step-size 

for Faramnetiric is an interval equal to i th of the 
difference between the Lū and HIGH values in the 
plotting range (in units). 

When checked, the step-size is interpreted to represent 
pixels. When unchecked (default) the step-size is 
interpreted to represent units. 

See the Function plot type. 

See the Function plot type. 

See the Function plot type. 


m (4) and (>) move the cursor along the plot of the current function. 


(<4) moves the 


cursor to the next lower value of the independent 


variable and (>) moves the cursor to the next higher value of the 


independent v 
counter to the 


ariable. This may result in directional movement 
“direction” implied by the arrow keys. A parametric 


plot can be traced through an unlimited range of the independent 
variable so you will be able to press (>) or (€) indefinitely in 
TRACE mode, even beyond the plotted interval. 

a (å) and (F) jump the cursor between functions when multiple 
functions are plotted. 
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Special Notes 


a Algebraic expressions should be entered in complex form, | £F 
where F and & are each expressions involving the independent 
variable, 

a Programs should take nothing from the stack and return one 
complex number result. 


Examples 


Example 1: Display the parametric example plot, LISSA: 
x(t) = 3sin 3t, y(t) = 2sin 4t. If necessary, type in F 
to install the EXAMPLES directory then: 


VAR 


[ano cnv [TRACE] | EDIT 


After plotting, press (œ) CLOT) to review the PLOT forms 
that generated the plot. Experiment by changing values or settings 
and redrawing the plot. 


Example 2: Do the two particles described below parametrically 
actually collide between t = 0 and t = 6.5 or do their 
path traces merely cross? 


Particle 1: x(t) = g = St, y(t) = 4t — 5. 


Particle 2: x(t) = 2sin Ft, y(t) = —3 cos 5t. 
Step 1: In the Parametric PLOT form, enter a list containing the 
two parametric expressions into 
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Step 2: 


Set the independent variable, the display and plotting ranges, 
simultaneous plotting, and the tick-spacing as shown. 


PLOT OPTIONS 
INDEP: T LO: & 41:6, 5 
of ARES X CONNECT yf SIMULT 
STEP: Df 14 _PIRELS 


H-TICK: 1 Y-TICK: 1 APINELS 
TICK SPACING UNITS ARE PIXELS? 


Step 3: 


23 


Step 4: 


TRACE (so @®)as 


necessary 


Ooo ee ee 


Erase PICT and draw the plot. Watch to see if the two plots 
turn on the same pixel at the same time—a possible collision. 


[zoo [cnwi [TRACE] | EMIT 


After watching the plot, you suspect that the point (0,3) is a 
likely collision spot. Turn on TRACE and the coordinates 
viewer and move the cursor over to the suspected point. 
Note that it occurs at t = 2, which after substituting back 
into the original equations prove that there is a collision. 


LE PE E 
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Differential Equation Plots | 


Differential equation plotting is covered in detail in chapter 19. For 


an additional example of a differential equation Pek, install 


necessary), and then press EXAM PLOTS 


Special Notes 


m The Diff Eq plot type uses the ares element of PPAR in a special 
way. It expects the two strings that normally contain axis-labels 
to each contain an integer. The integers indicate which solution 
component to plot on each axis (“0” indicates the independent 
variable, “1” indicates the first (or only) solution component, 


Gey 


solution), and so forth. 


indicates the second solution component (for a vector-valued 


Conic Plots 


The equation for a conic section is second degree or less in both z and 
y. For example, the following equations are all valid equations for 


plotting conic sections: 


z? +y?+4e+2y—5=0 (circle) 


5a? + 3y? — 18 =0 
— 4r + 3y4+2=0 
Qe? — 3y + 3y- 5=0 


(ellipse) 
(parabola) 
(hyperbola) 
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EQ: 


INDEF: % H-VIEW: -6.5 6.5 STEP: Df 14 PIXELS 

VEN: -3.1 3.2 H-TICK: 10 ¥-TICK: 1B g PINELS 
ENTER FUNCTION(S) TO PLOT ENTER INDEPENDENT VAR NAME 
EMIT fewoos] | orts JERAZE| DRAH] emri | ANE] OK | 


The Default CONIC Plot Screens 


: SPLOT OPTION 
INDEF: HMM LO: DF It Hi 
g ARES y CONNECT DEPHD: 'Y 


The Conic PLOT Form 


hen TEL 


HETES 


Shows the current angle mode. Change it by pressing 
one or more times or by using CHOOS. 
Enter the expression, equation, or program to be 
plotted. 

Enter the name of the independent variable. 

Enter the horizontal display range in the two fields, 
low endpoint in the left and high endpoint in the 
right. 

Enter the vertical display range in the two fields, low 
endpoint in the left and high endpoint in the right. 
Opens the PLOT OPTIONS form. 
Erases the PICT screen (without displaying it). 
Stores all of the values in their appropriate places in 
the reserved variables, EQ and PPAR, and draws 
the plot accordingly, leaving you in the PICTURE 
environment when finished. 


The Conic PLOT OPTIONS Form 


Enter the name of the independent variable. 

Enter the smallest value of the independent variable 
that you want plotted. 

Enter the largest value of the independent variable 
that you want plotted. Plotting range can be different 
than display range (see page 24-3). 

See the Function plot type. 

See the Function plot type. 

Enter the dependent (or second independent) variable. 
This determines the resolution of the plot. It is the 
horizontal distance (in units or pixels—see next field) 
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between two plotted points. The default step-size for 
cis an interval equal to 1 pixel. 


When checked, the step-size is interpreted to represent 
pixels. When unchecked (default) the step-size is 
interpreted to represent units. 

See the Function plot type. 

See the Function plot type. 


See the Function plot type. 


Special Notes 


m For conic plots, the HP 48 actually plots the two branches of 
the conic section separately. This may introduce one or two 
discontinuities in the connected graph. Specifying a smaller step size 
(decreasing the interval between plotted points) helps eliminate 
visual discontinuities. 

a If flag -1 (Principal Values) is set, the Conic plot will only display 
its principal branch (half of the plot). Clear flag -1 and redraw to 
plot the entire conic section. 

m Equations that are higher than second-order in the independent 
or dependent variable are converted to their second-order Taylor 
approximations before being plotted. 

m Conic is a useful plot type for plotting systems of equations 
involving two variables where none of the equations are higher than 
second order in either variable (see Example 2 in “Truth Plots” for 
a sample application). 


Example: Display the conic example plot, ELLIP: 
5a? +3y? — 18 = 0. If necessary, type in T 
the EXAMPLES directory then: 


“to install 


VAR 


prai 
| ae 


After plotting, press (CANCEL) (>) ELOT) to review the PLOT forms 
that generated the plot. Experiment by changing values or settings 
and redrawing the plot. 
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Truth Plots 


Truth plots evaluate expressions that return true (any nonzero real 
number) or false (0) results. At the coordinates for each pixel, the 
pixel is turned on if the expression is true—it’s unchanged if the 
expression is false. 


The Default TRUTH Plot Screens 


PLOT OPTIONS $ X 
INDEF: RED Le DF 1t we OF 1+ 
DEPNE: ‘YL DF ILE aE DELL 
STEP: Df lt PIXELS yw AKES 


TYPE! Truth 
EQ: 


INDEP: 3g H-VIEH: -6.5 6,5 
VME: -3.1 3.2 


ENTER FUMCTIONCS): TO PLOT 
EMT [CHOOs| | OPTS [ERASE] ORAL 


H-TICK: 1@ Y-TICK: 16 yw PIKELS 


ENTER INDEPENDENT VAR MAME 
es ee ee OAN] ok 


The Truth PLOT Form 


gi Shows the current angle mode. Change it by pressing 
one or more times or by using EHOOS. 

Eg: Enter the truth-valued expression, inequality, or 
program to be plotted. 

IHDEF: Enter the name of the independent variable. It will be 
plotted on the horizontal axis. 

H-YIEH: Enter the horizontal display range in the two fields, 
low endpoint in the left and high endpoint in the 
right. 


Enter the vertical display range in the two fields, low 
endpoint in the left and high endpoint in the right. 
Opens the PLOT OPTIONS form. 

2 Erases the PICT screen (without displaying it). 
CRAH Stores all of the values in their appropriate places in 
the reserved variables, FQ and PPAR, and draws 
the plot accordingly, leaving you in the PICTURE 
environment when finished. 


The Truth PLOT OPTIONS Form 


IHDEF: Enter the name of the independent variable. 
Lis Enter the smallest value of the independent variable 
that you want plotted. Plotting range for Parametric 
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plots are usually different than display range (see page 
24-3). 

HI: Enter the largest value of the independent variable 
that you want plotted. Plotting range can be different 
than display range (see page 24-3). 


DEPHD: Enter the dependent (or second independent) variable. 
It will be plotted on the vertical axis. 

Lis Enter the smallest value of the dependent variable 
that you want plotted. 

HI: Enter the largest value of the dependent variable that 
you want plotted. 

STEP: This determines the resolution of the plot. It is the 


horizontal distance (in units or pixels—see next field) 
between two plotted points. The default step-size for 
Truth is an interval equal to 1 pixel. 

FISELS When checked, the step-size is interpreted to represent 
pixels. When unchecked (default) the step-size is 
interpreted to represent units. 


ASES See the Function plot type. 
H-TICE See the Function plot type. 
-TICE See the Function plot type. 
FISELS See the Function plot type. 


Special Notes 


m Unless otherwise specified, every pixel in the display is evaluated. 
For a full-size display, this means EQ must be evaluated 8,384 times 
(compared to 131 times for the average function plot). You can 
speed up the plot by specifying a smaller z and y plotting range 
(see Example 2 below). 


Examples 


Example 1: Display the conic example plot, PTRN: (£? + y?) 
mod 2 < 4. If necessary, type in TEACH to install the 
EXAMPLES directory then: 
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VAR 


WEN N 


After plotting, press (CANCEL) (>) (PLOT) to review the PLOT forms 
that generated the plot. Experiment by changing values or settings 
and redrawing the plot. 


Example 2: Plot the solution set for the following system of 
inequalities: x + y > 2, 4y < xz + 8, 2y > 3x — 6. 


Step 1: Create a single ue expression: 
“ae '. Store it in the variable INEQ. 


Step 2: Create a list of the three inequalities with me ey 
23 signs converbed to D signs (=): £ REY 


+. Store the list in the variable N FOL. 


Step 3: Begin the PLOT application, change the plot type to Ceni, 
reset the plotting defaults, and choose NEQL for the field 
ERE, 


TO @) eC 
CED 0K 
mir z 


INDEF: F “He Veh: TER 6.0 
_AUTOSCALE V-VIEH: -3,1 3,2 


ENTER FUNCTIONS) TO PLOT 
EDIT [CHOO] | OFT [ERASE[ DRAH 


Step 4: Erase PICT and plot the three lines. (Note that these 
equations meet the requirements for Conic plots.) After 
drawing use %4 to determine the region of interest for 
ene 


23-16 Plot Types 


Step 5: Return to the PLOT form, change the plot type to Truth, 
choose the truth expression INEQ into the : field, and 
reduce the plotting range to the region of interest that you 
determined from looking at the Conic plot. 

INDEF: HO Lk-įi H:S 


(NXT) (CANCEL) (4) (a) T (¥) 
WM) oF DEPND: Y LE: -į Hi: 4 


= C 1 CA ENTER) 5 STEP: _PIRELS yf AKES 
ENTER) (>) 1 CA) (ENTER) 4 H-TICK: 16 Y-TICK: 1 yf PIRELS 


ENTER ENTER INDEP VAR INCREMENT 
EMT ee a ee 


PLOT OPTION 


Step 6: Draw the truth plot, without erasing PICT first. The truth 
plot will be superimposed over the lines drawn previously. 


LTTE EE TT fehe] 


Statistical Plots _ 


You can plot statistical data three ways: 


m Scatter Plot. For two variables, their values at each data point are 
depicted by a dot in the z-y plane. 


a Bar Chart. For one variable, its value at each sequential data point 
is shown by a vertical bar. 


a Histogram. For one variable, the number of times its value falls 
within certain ranges—called bins—is depicted by a vertical bar. 


Statistical plots use data stored in the reserved matrix X DAT 
variable, which plays a role for statistics analogous to FQ for function 
plotting and solving. 
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Histogram Plots 


A histogram divides the range of values of one variable into a number 
of 6ins and for each bin shows the number of data points for which the 
variable value falls within the bin. It shows the relative frequency—the 
maximum y value is the total number of data points. 


The Default HISTOGRAM Plot Screens 


WID: DELt H-WEM: -6,5 6.5 H-TICK: 16 Y-TICK: 1G PIRELS 


_AUTOSCALE Y-WIEW: -3,1 3.2 


ENTER DATA TO PLOT 
EMT [choos] [OPTS JeRASe] DRAH] 


DRAW AXES BEFORE PLOTTING? 
oo o [eche  jeaneL| OE] 


The Histogram PL.OT Form 


BOAT: Enter the data matrix or the name of the data matrix 
containing the data to be plotted. 

EAL: Enter the column number in X DAT that contains the 
data to be plotted. 

HID: Enter the desired bar width. The default sets the 
width of each bar equal to one user-unit. 

Hew ER Enter the horizontal display range (in user-units) 
in the two fields, low endpoint in the left and high 
endpoint in the right. 

Ye ERa Enter the vertical display range (in user-units) in the 
two fields, low endpoint in the left and high endpoint 
in the right. 

AUTESCALE: When checked, the horizontal display range is set to 

match the range of the data in the selected X DAT 

column and the vertical display range is set so that all 
bars will fit vertically into the display, regardless of 
the actual distribution. When unchecked, the display 
uses the display ranges indicated by the H-¥ IEH and 

YeVIE fields. 

Opens the PLOT OPTIONS form. 

Erases the PICT screen (without displaying it). 

Stores all of the values in their appropriate places in 

the reserved variables, X DAT, PPAR, and SPAR 
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and draws the plot accordingly, leaving you in the 
PICTURE environment when finished. 


The Histogram PLOT OPTIONS Form 


See the Function plot type. 
See the Function plot type. 
See the Function plot type. 
See the Function plot type. 


A bar chart shows the values of one variable in the order they appear 
in the statistical matrix. 


The Default BAR Plot Screens 


PLOT OPTIONS 


TYR 
zot:  <o: 1 

win: DF Lt H-vEH: -6.5 6.5 
AUTOSCALE Y-VIEW: -3,1 3.2 


ENTER DATA TO PLOT 
| Emt (cuon [OPTS JERASELORAL 


jases 
H-TICK: 16 V-TICK: 16 PIKELS 


DRAM ARES BEFORE PLOTTING? 
O i o o decHej o [eaNeL| DE | 


The Bar PLOT Form 


Enter the data matrix or the name of the data matrix 
containing the data to be plotted. 
Enter the column number in X DAT that contains the 
data to be plotted. 
HID: Enter the desired bar width. The default sets the 
width of each bar equal to 1 user-unit. 
ZWE Enter the horizontal display range (in user-units) 
in the two fields, low endpoint in the left and high 
endpoint in the right. 
Ye IERE Enter the vertical display range (in user-units) in the 
two fields, low endpoint in the left and high endpoint 
in the right. 
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AUTOSCALE: When checked, the horizontal display range is set 
from 0 to n, where n is the number of data points in 
X DAT and the vertical display range is set so that 
all bars will fit vertically into the display and HIP: 
set to the default (1 unit per bar). When unchecked, 
the display uses me display ranges indicated by the 

4 and ¥-VIEW fields. 

Opens the PLOT OPTIONS form. 

Erases the PICT screen (without displaying it). 

Stores all of the values in their appropriate places in 

the reserved variables, S DAT, PPAR, and X PAR 

and draws the plot accordingly, leaving you in the 

PICTURE environment when finished. 


The Bar PLOT OPTIONS Form 


See the Function plot type. 
See the Function plot type. 
See the Function plot type. 
See the Function plot type. 


Scatter Plots 


A scatter plot shows the relationship between two variables by 
plotting a point at each z-y coordinate pair. For variables that 
are statistically correlated, the points should cluster along a curve 
representing the statistical model. 


The Default SCATTER Plot Screens 


TYPE: Scatter 
zT: FR cos: j 2 

H-VIEH: -6.5 6.5 
AUTOSCALE V-VEH: -3.1 3.2 


ENTER DATA TO PLOT 
EMT [cons] [OPTS JERAZE| DRAH] 


H-TICK: 10 ¥-TicK: 10 g PIRELS 


DRAW AXES BEFORE PLOTTING? 
E ecn] amL| Dk | 
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The Scatter PLOT Form 


ERA 
DRAH 


Enter the data matrix or the name of the data matrix 
containing the data to be plotted. 

Enter the column numbers in XY DAT that contain the 
data to be plotted. The left field indicates the column 
to be plotted along the horizontal axis and the right 
field indicates the column to be plotted along the 
vertical axis. 

Enter the horizontal display range (in user-units) 

in the two fields, low endpoint in the left and high 
endpoint in the right. 

Enter the vertical display range (in user-units) in the 
two fields, low endpoint in the left and high endpoint 
in the right. 

When checked, the horizontal and vertical display 
ranges are set so that all plotted points are displayed 
with as little extra space as possible. When 
unchecked, the display uses the display ranges 23 ! 
Opens the PLOT OPTIONS form. 

Erases the PICT screen (without displaying it). 
Stores all of the values in their appropriate places in 
the reserved variables, VDAT, PPAR, and X PAR 
and draws the plot accordingly, leaving you in the 


PICTURE environment when finished. 


The Scatter PLOT OPTIONS Form 


Special Notes 


See the Function plot type. 
See the Function plot type. 
See the Function plot type. 
See the Function plot type. 


a After drawing the Scatter plot, press STAT to superimpose the 
a plot of the current regression model on the Scatter plot. This 


temporarily changes the plot type to Fur 


am so that executing a 


zoom will redraw the regression curve but not the scatter data. 
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Plotting Functions of Two Variables 


There are six different plot types that can be used to help you 
visualize functions of two variables. Some of these display simulated 
three-dimensional surfaces; other provide distinct two-dimensional 
views of an underlying (but not displayed) “three-dimensional” 
function. 


Sampling Grid 


Functions of two independent variables need two inputs in order to 
generate an output. The HP 48 uses a two-dimensional sampling grid 
of points whose two coordinates provide the two inputs required. 


Each of the six plot types that use functions of two variables allow you 
to determine the size of the sampling grid. By default, it consists of 80 
points—10 columns by 8 rows. Increasing the number of points in the 
sampling grid increases the time it takes to draw the plot—and the 
detail with which the function is plotted. 


However, for plots of functions of two variables, more detail does not 
always translate into a more meaningful plot. Each combination of 
function and plot type has its own built-in optimum sampling grid 
size that is neither too small to properly reflect the function nor too 
large to obscure the important aspect. You will probably need to 
experiment a bit with the sampling grid dimensions when you first 
plot a function. 


Output Grid 


The six plot types each transform the sampling grid into an output 
grid, using the function to guide the transformation. However, each 
plot type makes use of the sampling grid in different ways. 


Three of them—Slopefield, Ps-Contour, and Gridmap—take each set 
of sample coordinates and use the current equation to transform them 
into a new two-dimensional output grid that enables you to visualize 
the nature of the transforming equation. The plot you see is nothing 
more than the two-dimensional output grid. 
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Output Grids 


ae a a 
em eet tl gt lt 
(7 Son oe ae IE 
eT a ce ma tt el a ett 
see ee en e 
en nee 
et ae pnt ie agra apr up apt apt yg 
AE gee et et ott apt tl fl 
core ee eee a a Slopefieid/Ps-Contour 


Sampling Grid 


Gridmap 


Transforming Sampling Grid to Output Grid 


A fourth plot type, YSlice, performs the same transformation as 

Wireframe, but displays the output very differently. Instead of ce 
showing the entire output surface at once, YSlice plots, one after the 

other, two-dimensional cross-sections of the surface perpendicular to 

the y-axis. It draws one plot for each row in the sampling grid. Once 

it has completed drawing all of the “slices,” it creates and runs an 
animation using each “slice” as one frame. This allows you to visualize 

a moving slice through the computed surface. 
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The YSLICE View 
23 


The final two, Wireframe and Pr-Surface, transform the 2-dimensional 
sample grid into a three-dimensional output surface. The plot that 
you see is the output surface as viewed from a specified vantage 
point—the eyepoint. The only part of the surface plotted will be that 
within the within a region in 3-dimensional space, called the View 
Volume, defined by ranges on each of the three coordinate axes. 


y Top View 
Veer 


-View Volume 


Ves 


View Plane (parallel to xz-plane) 


7 A a 
| _1 y-axis unit 
| ¥ 


Eyepoint (Xe,Ye,Ze) Plot Display Screen 


The Relationship of the Eyepoint, View Volume, and Plot Display 
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Note that the three-dimensional coordinate system on the HP 48 
is somewhat constrained compared to its abstract, mathematical 
counterpart. Specifically: 


The plot display screen does not rotate in space; it always stays 
parallel to the zz-plane and perpendicular to the y-axis. This means 
that, visually, “height” is always along the z-axis, “width” along the 
z-axis, and “depth” along the y-axis. 

The y-axis is always oriented so that negative y-values are “nearer” 
and positive y-values “farther” away from the plot display. 

The eyepoint must be at least one unit “nearer” than Ynear 

(Ye < Ynear — 1) and can never exist “within” the View Volume. 
Whenever you move the eyepoint, you also move the plot display 
screen so that it remains exactly one unit away in the direction of 
the y-axis. 

You cannot plot a “top” view of a function (looking down onto the 
zy-plane) simply by moving the eyepoint. (You may simulate this 
by transforming coordinates, however.) 


Slopefield Plots 


The Slopefield plot type draws a lattice of line segments whose slopes 
represent the value of the function, f(z,y), at their centerpoint. 

Using Slopefield allows your eye to pick out integral curves of the 
differential equation y’ = F(z, y). It is quite useful in understanding 
the “arbitrary constant” in antiderivatives. 


The Default SLOPEFIELD Plot Screens 


PLOT OPTIONS 
H-LEFT: Bape R-RIGHT: Í 
Y-HEAR: —1 Y-FaR: Í 


TYRE: Slo efield á: De 
EQ: 


INDEP: X STEPS: 16 
DEPMD: ‘Y STEPS: & 


ENTER FUMCTION(S) TO PLOT 
EDIT [choni] LOFTS [ERASE] DRAH] 


ENTER MINIMUM # WEH-VOLUME VAL 
peo d [odani j oe 
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The Slopefield PLOT Form 


at Shows the current angle mode. Change it by pressing 
one or more times or by using CHODE. 
Egi Enter the current expression, equation, or user-defined 


function to be plotted. Names of variables containing 
expressions, equations, or UDFs may be used in place 
of the objects themselves. 

Enter the name of one of the independent variables. 
Enter the number of columns in the sampling grid. 
Enter the name of the second independent variable. 
Enter the number of rows in the sampling grid. 
Opens the PLOT OPTIONS form. 

Erases the PICT screen (without displaying it). 
Stores all of the values in their appropriate places in 
the reserved variables—EQ, PPAR, and VPAR— 
and draws the plot accordingly, leaving you in the 
PICTURE environment when finished. 


The Slopefield PLOT OPTIONS Form 


BoLEPT: Enter the horizontal display range, corresponding to the 
“RIGHT: first independent variable (entered in IHDEF). 

HERR E Enter the vertical display range, corresponding to the 
oFRR second independent variable (entered in DEFHE). 
Examples 


Example 1: Display the Slopefield example plot, SPFLD: y = ean, 
If necessary, type in TEACH to install the EXAMPLES 


directory and then: 


Press ERAM PLOTS 
SPFL 


After plotting, press (@)CELOT) to review the PLOT forms 
that generated the plot. Experiment by changing values or settings 


and redrawing the plot. 
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Example 2: Plot the Slopefield of the differential equation, 


Step 1: 


Step 2: 


E 


Step 3: 


Step 4: 


Step 6: 


Step 7: 


y'(z) = x*. Then superimpose the solution of the 
equation with a particular initial condition. 
In the Slopefield PLOT form, enter the expression (‘#2 ') 
into Ett: , and set the display ranges to [-3 3] (horizontal) 
and [-1 5] (vertical). Set the independent step variable to 10 
steps and the dependent step variable to 8 steps. 


Plot the slopefield. 


DRAM 


Turn on TRACE mode, press (F) seven times and (>) one 
time to jump to a point in the lower left corner of the screen, 
and press to put the coordinates onto the stack. 
Return to the PLOT form and change the plot type to Diff 
Eq. Then highlight the solution variable’s INIT: field and 
press ERLE so that the coordinate point (a 
tagged list) is sitting on level 1 of the stack. 

Press CEST “Obs to remove the IHPLT 
tag. Press GEJ to separate the two coordinates, 
and then ()(CONT) ÜE to store the y-coordinate as the 
initial solution value. 

Highlight the independent variable’s [HIT field and press 
CAGE: HE- to retrieve the r-coordinate as the 
initial independent value. Then set the FIMAL: value to 3. 
Set the step-size to 0.1. 
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Step &: Draw the plot without erasing first so as to superimpose the 
Diff Eq plot on the previous Slopefield plot. 


On DRL 


Wireframe Plots 


The Wireframe plot type draws an oblique-view, perspective, 3D plot 
of a wire-frame model of the surface determined by Z = F(z, y). 
, 23 Each point in the sampling grid is perspective-projected onto the 
display screen along the line connecting the sample and the eyepoint 
(X.,Ye,Ze). 


View Volume 
ae, 


Pe i . 


View Screen 


-j Eye Point (XE, YE, ZE) 
maD) 


Perspective Projection 


Neighboring samples are connected by straight lines. The 
sampling grid is determined by the “base” of the View Volume 
(Xieft Xright Y near Y far) . 
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The Default WIREFRAME Plot Screens 


TRE: Wireframe £: De 
EG: 
INDEP: 1 STEPS: 16 


DEPHD: Y STEPS: 3 


1E: -3 


ENTER MINIMUM X$ VIEH-YOLUME VAL 
emt Co Oe 


ENTER FUMCTIOMCS) TO PLOT 
EMT [CHODA] | OPTS JERASE] DRAH] 


The Wireframe PLOT Form 


a3 Shows the current angle mode. Change it by pressing 
(#/-) one or more times or by using & 3: 

EGE Enter the current expression, equation, or user- defined 

functions to be plotted. Names of variables containing 

expressions, equations, or UDFs may be used in place 

of the objects themselves. 

Enter the name of one of the independent variables. 

Enter the number of columns in the sampling grid. 

Enter the name of the second independent variable. 

Enter the number of rows in the sampling grid. 

Opens the PLOT OPTIONS form. 

TASE Erases the PICT screen (without displaying it). 
DER Stores all of the values in their appropriate places in 
the reserved variables—EQ, PPAR, and VPAR— 
and draws the plot accordingly, leaving you in the 
PICTURE environment when finished. 


The Wireframe PLOT OPTIONS Form 


Enter the z-axis range (“width”) of the View Volume. 
Enter the y-axis range (“depth”) of the View Volume. 


Enter the z-axis range (“height”) of the View Volume. 


Enter the z-coordinate of the eyepoint. Use the 
midpoint of the z-axis range for the View Volume 
if you want the plot “centered” horizontally in the 
display. 
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YE: Enter the y-coordinate of the eyepoint. It must be 
at least one unit smaller than the value for Y-HEAR: 
above. The greater the difference between YE: and 


ka, the “farther away” the plot will appear. 


ZE: Enter the z-coordinate of the eyepoint. Use the 
midpoint of the z-axis range for the View Volume if you 
want the plot “centered” vertically in the display. 


Example: Display the Wireframe example plot, WIRE : 
z = gy — ry’. If necessary, type in TEACH to install the 
EXAMPLES directory and then: 


Press E 


NXT) h 


ELD EE o [emt [eaw] 


After plotting, press (@)ELOT) to review the PLOT forms 
that generated the plot. Experiment by changing values or settings 
and redrawing the plot. 


Pseudo-Contour Plots 


The Ps-Contour plot type plots a lattice of line segments, each tangent 
to a contour of the function (a curve satisfying F(z,y)=constant). 

It computes a tangent for each point in the sampling grid. The 
Ps-Contour produces a “fast” contour plot, allowing your eye to pick 
out the integral curves (contours) without actually plotting them. 
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The Default PS-CONTOUR Plot Screens 


PLOT OPTIONS 
TRE: Ps-Comtour a: De 
Eğ: 


INDEF: X STEPS: 10 

DEPNO: Y STEPS: & 

ENTER FUNCTION(S) TO PLOT ENTER MINIMUM # VIEW-OLUME VAL 
EMT [cwoos| [opts [ERAZE| ORAH] Se ee | o kanet) Ok | 


The Ps-Contour PLOT Form 


ae Shows the current angle mode. Change it by pressing 
one or more times or by using CHOOSE. 
Eg: Enter the current expression, equation, or user-defined 


function to be plotted. Names of variables containing 
expressions, equations, or UDFs may be used in place 
of the objects themselves. 


THDEPs Enter the name of one of the independent variables. 23 
STEPS: Enter the number of columns in the sampling grid. 

DEFHD: Enter the name of the second independent variable. 

STEPS: Enter the number of rows in the sampling grid. 

OPTS Opens the PLOT OPTIONS form. 

ERASE Erases the PICT screen (without displaying it). 


DRAL Stores all of the values in their appropriate places in 
the reserved variables—EQ, PPAR, and VPAR— 
and draws the plot accordingly, leaving you in the 
PICTURE environment when finished. 


The Ps-Contour PLOT OPTIONS Form 


Enter the horizontal display range, corresponding to the 
first independent variable (entered in INDEF). 


Enter the vertical display range, corresponding to the 
second independent variable (entered in DEFHE). 


Example: Display the Ps-Contour example plot, PSCN: z = 
If necessary, type in TEACH to install the EXAMPLES 
directory and then: 
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Press EXAM PLOTS 
PECH 


After plotting, press (CANCEL) (>) (PLOT) to review the PLOT forms 
that generated the plot. Experiment by changing values or settings 
and redrawing the plot. 


Y-Slice Plots 


The YSLICE plot type draws a series of cross-sections (each 
perpendicular to the y-axis) of the surface determined by the current 
equation. It draws one plot for each row in the sampling grid. Once 

it has completed drawing all of the “slices,” it creates and runs an 
animation using each “slice” as one frame. This allows you to visualize 
a moving slice through the computed surface. 


The Default YSLICE Plot Screens 


SPLOT OPTIONS $ 
TYRE: Y-Slice K-LEFT: ERB H-RIGHT: 1 
EQ: Y-NEAR: — Í Y-FAR: 1 
INDEP: $ STEPS: 10 Z-LoW: -1 2-HIGH: 1 
DEPND: Y STEPS: B _ SAVE ANIMATION 
ENTER FUNCTION(S) TO PLOT ENTER MINIMUM 4 WIEW-YOLUME VAL 
Pept [chons] | OPTS [ERASE DRAH] EDIT | ee] oe 


The Y-Slice PLOT Form 


om Shows the current angle mode. Change it by pressing 
ŒA) one or more times or by using CHOOS 
Em: Enter the current expression, equation, or useedeaned 


function to be plotted. Names of variables containing 
expressions, equations, or UDFs may be used in place 
of the objects themselves. 

THDEP s Enter the name of one of the independent variables. 
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Enter the number of columns in the sampling grid. 
Enter the name of the second independent variable. 
Enter the number of rows in the sampling grid. 

Opens the PLOT OPTIONS form. 

Erases the PICT screen (without displaying it). 

Stores all of the values in their appropriate places in 
the reserved variables—EQ, PPAR, and VPAR—and 
draws the series of plots accordingly. Once it has drawn 
all of the slices, it animates them in a continuously 


repeating loop. Press to stop the animation. 


The YSlice PLOT OPTIONS Form 


Enter the z-axis range (“width”) of the View Volume. 
Enter the y-axis range (“depth”) of the View Volume. 


Enter the z-axis range (“height”) of the View Volume. 


= When checked, the series of “slices” used in the 
ANIMATION animation are put onto the stack and the number of 
slices put onto level 1 of the stack. When unchecked, 
all “slices” except the current one are deleted once the 
PICTURE environment is exited. 


Example: Display the YSlice example plot, SLICE: z = z°y — zy. 
If necessary, type in TEACH to install the EXAMPLES 
directory and then: 


Press (CANCEL) to halt animation. 


After plotting, press (CANCEL) (@)(PLOT) to review the PLOT forms 
that generated the plot. Experiment by changing values or settings 
and redrawing the plot. 
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Gridmap Plots 


The GRIDMAP plot type transforms (maps) the specified rectilinear 
sampling grid via the current complex-valued function. The 
coordinates (a complex number) of each point in the sampling grid are 
the inputs for the function which then maps the coordinates into the 
output grid. You can control how much of the output grid is displayed 
by adjusting the z- and y-ranges for the View Volume. 


The Default GRIDMAP Plot Screens 


rildama 


T ~ 
EQ: 


INDEP: STEPS: 10 #H-RGHT: 1 
DEPND: Y STEPS: & YY-MEAR:— 1 YY-FAR: 1 
ENTER FUMCTION(S3 TO PLOT ENTER MINIMUM X WEW-VOLUME VAL 
(i ee [ERASE| DRAH] (Emt ee Ok | 
The Gridmap PLOT Form 
ai Shows the current angle mode. Change it by pressing 
one or more times or by using CHOMS. 
Elis Enter the current expression, equation, or user-defined 


function to be plotted. Names of variables containing 
expressions, equations, or UDFs may be used in place 
of the objects themselves. The function or expression in 
EQ should use a complex number argument. 
THDEF: Enter the name of one of the independent variables. 
STEP: Enter the number of columns in the sampling grid. 
Enter the name of the second independent variable. 
Enter the number of rows in the sampling grid. 
Opens the PLOT OPTIONS form. 
Erases the PICT screen (without displaying it). 
Stores all of the values in their appropriate places in 
the reserved variables—EQ, PPAR, and VPAR— 
and draws the plot accordingly, leaving you in the 
PICTURE environment when finished. 
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The Gridmap PLOT OPTIONS Form 


Enter the horizontal display range. 


Enter the vertical display range. 

Y-FAR! 

Enter the horizontal range of the input sampling grid, 
corresponding to the first independent variable (entered 
in IHDEF). 


Enter the vertical range of the input sampling grid, 
corresponding to the second independent variable 
(entered in DEFHE). 


Example: Display the Gridmap example plot, GRID: 
z + yi > sin(x + yi). If necessary, type in TEACH to 
install the EXAMPLES directory and then: 


Press EXAM FLOTS 
GRID 


After plotting, press () (PLOT) to review the PLOT forms 


that generated the plot. Experiment by changing values or settings 
and redrawing the plot. 


Parametric Surface Plots 


The Pr-Surface plot type draws an oblique-view, perspective, 

3D plot of a wire-frame model of the surface determined by 

F(u, v) = z(u, vjit y(u, v)j + z(u, v)k where u and v are drawn from 
the sampling grid (#1- and Y~ ranges). Pr-Surface combines the 
coordinate-mapping approach of Gridmap with the three-dimensional 
perspective plotting of Wireframe. 
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TYRE Pr-Surface d: De 


En: 
INDEP: 3i 


DEPHD: Y 
ENTER FUMCTIOM(S) TO PLOT 


EMT [choo | 


The Default PR-SURFACE Plot Screens 


PLOT OPTIONS 3 


R-LEFT: 


H-RIGHT: 1 
Y-MEAR: —1 Y-FAR: Í 
STEPS: 14 2-LoW: —İ 2-HIGH: 1 


HE: G YE: —3 ZE: 0 


ENTER MINIMUM ¥ VIEW-YOLUME YAL 
a | [kuyt kANiL] ok | 


STEPS: 9 


JERSE) DRAH] 


SSSH AND YY PLOT OPTIONS SEA 
HH-LEFT: BQ RH-RGHT:1 


Y¥-MEAR:— Í YY-FAR: 1 


ENTER MINIMUM HX RANGE VALUE 
ie [| [| - kawL[f ik] 


The Pr-Surface PLOT Form 


o8 
hy & 


Ema 


THDEF: 


Shows the current angle mode. Change it by pressing 
one or more times or by using ZHOOS. 

Enter the function as a list containing the three 
algebraic objects representing the parametric vector 
components. 

Enter the name of one of the independent variables. 
Enter the number of columns in the sampling grid. 
Enter the name of the second independent variable. 
Enter the number of rows in the sampling grid. 
Opens the PLOT OPTIONS form. 

Erases the PICT screen (without displaying it). 
Stores all of the values in their appropriate places in 
the reserved variables—EQ, PPAR, and VPAR— 
and draws the plot accordingly, leaving you in the 
PICTURE environment when finished. 
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The Pr-Surface PLOT OPTIONS Form 


Enter the z-axis range (“width”) of the View Volume. 


Enter the y-axis range (“depth”) of the View Volume. 


Enter the z-axis range (“height”) of the View Volume. 


HES Enter the r-coordinate of the eyepoint. Use the 
midpoint of the z-axis range for the View Volume 
if you want the plot “centered” horizontally in the 
display. 


YE: Enter the y-coordinate of the eyepoint. It must be 
at least one unit smaller than the value for -HERE 

The greater the difference between YE! and 

2, the “farther away” the plot will appear. 


ZE: Enter the z-coordinate of the eyepoint. Use the 
midpoint of the z-axis range for the View Volume if you 
want the plot “centered” vertically in the display. 


Bea tY Opens the XX AND YY PLOT OPTIONS form, in 
order to enter the sampling grid ranges. 


The Pr-Surface XX AND YY PLOT OPTIONS Form 


“Ta Enter the horizontal range of the input sampling grid. 
aT 


Enter the vertical range of the input sampling grid. 


Example: Display the Pr-Surface example plot, PSUR: 
F(u,v) = x(u,v)it y(u, v)j + z(u, v)k where 
z(u,v) = ucosv, y(u,v) = usin v, and z(u,v) = u. If 
necessary, type in TEACH to install the EXAMPLES 
directory and then: 
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Press EXAM PLOTS 
PSUR 


£ 


ELT ee a ee 


After plotting, press (CANCEL) (@)(PLOT) to review the PLOT forms 
that generated the plot. Experiment by changing values or settings 
and redrawing the plot. 


23 
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Advanced Plot Options 


Labeling and Locating the Axes 


To label the coordinate axes with the variable names: 


After the plot is drawn, press ERIT LABEL. The names 
of the independent and dependent variables and the coordinates 

(in user-units) of the largest and smallest displayed values for each 
variable are added to the plot. The figure below shows labels added 
to the plot of z? — 2 using the default settings. 


To label the axes with user-defined labels: 


3. 
4. 
5. 


. Press (CANCEL) to return to the stack, if necessary. 
. Enter a list containing the horizontal and vertical axis labels (as 


strings): € "A-label" "“v-label" 3 
Press ()(PLOT) FFAR ASES to store the labels. 


Press (4)(PICTURE) to display the plot again. 
Press ERIT LABEL. 


To have the axes intersect at some point other than (0,0): 


1. 
2: 


From the stack, press ()(3). 


Type in the complex number containing the desired point of 


intersection and press (ENTER). 
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to store the intersection 


3. Press ()(PLOT) FFRAE (NXT 
point. 
4. Press (>) PLOT) E 


axes intersection point. 


CRAH to redraw the plot using the new 


Plotting Programs and User-Defined Functions 


You can plot more than just expressions and equations—you can also 
plot programs. And your expressions, equations, and programs can 
include user-defined functions. 


You can plot a program if it takes nothing from the stack, uses 
the independent variable in the program, and returns exactly one 
untagged number to the stack: 


m Real result. Equivalent to the expressions f(x) (plot type Function) 
and r(@) (plot type Polar). For example, the program 
IF (Rie! THEN 'See°a-45es°2+358' ELSE 1000 END 
plots 


_ {323 — 45224350 ife <0 
He) = {ooo ifr >0 


Store the program in EQ, select autoscaling, and draw the plot. 


m Complex result. Equivalent to (x(t), y(t)) (plot type Parametric). 
For example, the program 


'£°E=2' SHUM t48- 


plots the parametric equations 


g=t? 2 and y=P—2t41 


Store the program in EQ, make 'T' the independent variable, select 
autoscaling, and draw the plot. 
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Plotting Range vs. Display Range 


The plotting range is the range of the independent variable (or 
variables) over which the current equation is evaluated. If you don’t 
specify the plotting range, the HP 48 uses the z-axis display range 
(specified by XRNG in (4)(PLOT) or by H~VIEH in ()(PLOT)) as 
the plotting range. However, you can specify a plotting range that’s 
different from the z-axis display range: 


= For Polar and Parametric plots, the independent variable isn’t 
related to the z-axis variable—so you specify the plotting range to 
control the range of the independent variable. 


a For Truth and Conic plots, you can shorten plotting time by 
specifying plotting ranges that are smaller than the z- and y-axis 
display ranges. These plot types require you to specify the 
dependent variable—you can specify its plotting range different from 
the y-axis display range. 


You can make PICT larger than its default size (131 by 64 pixels)— 
and either keep the same z and y scale factors (which extends the 
display range), or keep the same display range (which extends the 
scale and appears to “stretch” the plot. 


To check the current size of PICT: 


m Press PICT PICT (@)(RCL). You will see Graphic 
width height—the current dimensions of PICT. 


To change the size of PICT: 


a To keep the same scaling, enter two complex numbers (with © 3 
delimiters) specifying the coordinates of diagonally opposite corners 
in user-units, then press PICT FELE. 

m To keep the same display ranges, enter two binary integers (with # 
delimiter) specifying the horizontal and vertical sizes in pixels, then 


press Pid. EOE. 


The result of the PDIM (PICT dimension) command depends on the 
type of coordinates—user-units or pixels—though both forms change 
the size of PICT. 
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Example: Assume PICT is its default size, shown in figure (a) 
below. 


To double the z range of PICT in the horizontal 
direction and keep the same scales (units per pixel), enter 
f-18,-12 and (28,23 and press PIM . (PICT 
becomes #261 wide by #64 high in pixel units.) If you 
redraw the graph, the effect is to add more points to the 
graph at both ends, shown in figure (c). 
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{#0 #0} (10, 2) 


(5, -1) {#130 #63} 
(a) 
{#0 #0} 
{#261 #63} 
(b) 
(20, 2) 
(-10, -1) 
(c) 


Changing the Size of PICT 


To extend the plotting range beyond the limits of the display: 
1. Change the the size of PICT so that it encompasses the plotting 


range. Enter two complex numbers (with € > delimiters) specifying 
the coordinates of diagonally opposite corners in user-units, then 
press PICT: BERLE. 


2. Open the PLOT application and set the plotting ranges and display 
ranges. The display range may be smaller than the plotting range. 
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ERASE 


3. After all plot parameters are set, press ORAL to draw the 
plot. You will only see a portion of the plot in the display. 

4. Press (4)(PICTURE) and use the arrow keys to scroll around and 
view the larger plot. Press (|) (PICTURE) again to exit scrolling 
mode. 


To use computed values for plotting or display ranges: 


1. In the PLOT or PLOT OPTIONS form, highlight the range field 
whose value you wish to compute. 

2. Press CALE to prepare for a side-calculation on the stack. 

3. Perform the desired computation. For example, if you want to use 


aE as one endpoint, you would press 3 (4)(zr) (x) 4 ©). 


4. If it is not already one, convert the result on level 1 to a real 


number by pressing (4,)(+NUM). 


5. Press. Oto return the result to the original field. 


Saving and Restoring Plots 
A plot can consist of several components: 


m The plot picture, a graphic object. 

m The current equation or equations, stored in the reserved variable 
EQ. 

m The current plot parameters, set in the PLOT forms, and stored in 
the reserved variable PPAR and, in the case of three-dimensional 
plot types, VPAR. 

a Flag settings that determine plotting or display options. 


You have the option to save any or all of these plot components in a 
variable so that you may retrieve them at a later time. Here are two 
useful approaches: 


1. Save just the plot picture—the “result”—in a variable. This is a 
simple procedure (see below) but each plot picture uses about one 
Kilobyte of memory. 

2. Save the current EQ, PPAR, VPAR (if necessary), and flag settings 
in a list. The plot can be reconstructed by restoring each of these 
to the values contained in the list. 


24-6 Advanced Plot Options 


The following set of procedures illustrate how to accomplish these 
approaches to saving and restoring plots. 
To save the current plot picture in a variable: 


1. After drawing the plot and while viewing it in PICTURE, press 
to send a copy of the plot to the stack as a graphics object. 
Press (CANCEL) to return to the stack. 

2. Enter a name for the plot (‘Fi', for example) and press 


To view a plot picture that was previously stored in a variable: 
1. Press and then (f>) and the menu key corresponding to the 


variable containing the plot picture (F1, for example) to recall 
it to the stack. 

2. Press EPET: PIET to store the plot picture in 
PICT. 


3. Press (€)(PICTURE) to view the plot picture. 


To save a “reconstructable” version of the current plot: 


1. After drawing the plot, press to return to the stack. 

2. Recall the current contents of EQ, PPAR, and VPAR (if the 
current plot is a three-dimensional plot) to the stack by pressing 
and then EG PPAR and “FAR (if necessary). You 
may need to use to switch menu pages to find each of these 
variables. 

3. Press (4)(MODES) FLAG EELE to recall the current flag 
settings to the stack. 

4. You should have three or, if you included VPAR, four new objects 
on a ie stack. Enter the number (3 or 4) and press LIST 

TET to group these objects into a list. 

5. Enter a name for the list and press (STO). 


To reconstruct a plot from its stored version: 


1. Press and then the menu key associated with the variable 
containing the stored version (in list form) of the plot. 
2. Press 7 GEI (DROP) to disassemble the list and put 


the componente: onto the stack. 


3. Press ()(MODES) FLAG STOF to restore the flag 


settings. Note that your current flag settings will be lost. 
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4. If the plot is a three-dimensional plot, press (1), type VF AF and 
press to restore VPAR. 

5. Press (|), type FFRAE and press to restore PPAR. 

Press (#)(PLOT) (4) EG to restore EQ. 

7. Press (¢>)(PLOT) ERASE DRA to redraw the plot. 


D 
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The Equation Library 


The Equation Library is a collection of equations and commands that 
enable you to solve common science and engineering problems. The 
library consists of more than 300 equations grouped into 15 technical 
subjects containing more than 100 problem titles. Each problem 

title contains one or more equations that help you solve that type of 
problem. Appendix G contains a table of the groups and problem 
titles available in the Equation Library. More detailed information 
about each equation set is given in the HP 48G Series Advanced 
User’s Reference. 


Solving a Problem with the Equation Library 
Follow these steps for solving a problem using the Equation Library: 


1. Press (¢>)(EQLIB) to start the Equation Library. 


2. Set the unit options you want by pressing the $1 
and UHITE menu keys. 


3. Highlight the subject you want, then press (ENTER). 
4. Highlight the title you want. 


ENGL, 


5. Optional—if you want to find out more about the equations in 
this set, press other keys as described in the next few sections. 


6. For each known variable, type its value and press the 
corresponding menu key. Press if necessary to access 
additional variables. 


7. Press 0L to start solving the problem. 
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10. 


. For each known variable, type its value and press the 
corresponding menu key. Press if necessary to access 
additional variables. 


Optional: Supply a guess for the unknown variable(s). This can 
speed the solution process or help to focus on one of several 
solutions. Enter a guess just as you would the value of a known 
variable. If you are working with multiple equations, press (") 
and then the variable menu key “MEAL after entering the guess 
(reconverting the menu label to white). 


Press (4) followed by the menu key of the variable for which 
yow’re solving. If you’re solving a set of equations, you can press 
(#4) ALL to solve for all remaining unknown variables—all 
variables not previously defined by you. 


Using the Solver 


W 
yo 


hen you select a subject and a title in the Equation Library, 
u specify a set of one or more equations. Then, when you press 


SOL‘, you leave the Equation Library catalogs and start solving 


th 


e equations you’ve selected. 


When you press OL’ in the Equation Library, the application 
does the following: 


25 


The set of equations is stored in the appropriate variable: EQ for 
one equation, FQ and Mpar for more than one equation. (Mpar is a 
reserved variable name used by the Multiple-Equation Solver.) 


Each variable is created and set to zero unless it already exists. (If 
the variable name has been used by the Solver before, then it is a 
global variable and therefore already exists—until you purge it.) 


Each variable’s units are set to the conditions you specified—SI 

or English units, and units used or not used—unless the variable 
already exists and has units dimensionally consistent with what you 
specified. (To change from English to SI units or vice-versa, you 
must first purge the existing variables or explicitly enter the units 
with the values.) 


The appropriate solver is started: the SOLVR application (see page 
18-7) for one equation, the Multiple-Equation Solver for more than 
one equation. 
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Because EQ and Mpar are variables, you can have a different EQ and 
Mpar for each directory in memory. 


Using the Menu Keys 


The actions of the unshifted and shifted variable menu keys for both 
solvers are identical. Notice that the Multiple-Equation Solver uses 
two forms of menu labels: black and white. The key shows 
additional menu labels, if required. In addition, each solver has special 
menu keys, which are described in the following table. You can tell 
which solver is started by looking at the special menu labels. (Or you 
can check the title—the title for a library equation in the HP Solve 
application starts with Eğ: .) 


Actions for Solver Menu Keys 


Operation SOLVE Multiple-Equation 
Application Solver 


Store value 


Solve for value 


Recall value 


BY BY 


Evaluate equation EXFR=S 

Next equation HHEH 

(if applicable) 

Undefine all ALL 
Solve for all (4) ALL 
Progress catalog E) FEL 
Set states HUSE MEAL 
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Browsing in the Equation Library 


When you select a subject and title in the Equation Library, you 
specify a set of one or more equations. You can get the following 
information about the equation set from the Equation Library 
catalogs: 


a The equations themselves and the number of equations. 
a The variables used and their units—you can also change the units. 


m A picture of the physical system (for most equation sets). 


Viewing Equations 


All equations have a display form—some equations also have a 
calculation form. The display form gives the equation in its basic 
form—the form you’d see in books. The calculation form includes 
computational refinements. If the equation has a calculation form, an 
# appears in the upper-left corner of the equation display. 


Operations for Viewing Equations and Pictures 


Key Action Example 
EGH Shows display form of current or | B = pound 
HSER next equation in Equation Writer 

format. 


ENTER Shows display form of current or 


next equation as an algebraic 


object. or (F) shows the 
next equation, (A) shows the 
previous. 


43TE Shows calculation forms by 
putting a list containing the 
current set of equations on the 
stack. 


Jigmi i 
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Viewing Variables and Selecting Units 


After you select a subject and title, you can view the catalog of 
names, descriptions, and units for the variables in the equation set 
by pressing SARS. The table below summarizes the operations 
available to you in the Variable catalogs. 


Operations in Variable Catalogs 


Key Action 


NXT Toggles between catalog of descriptions and catalog 
of units. 


Makes SI or English units active unless this 
conflicts with the units already defined for an 
existing (global) variable. Purge existing variables 
(or enter the specific units) to eliminate conflicts. 


UM ITS Toggles between units used or units not used. 


a0 AR Creates or changes all equation variables to have 
indicated unit type and usage. 


PUR G Purges all equation variables for this title in the 
current directory. This also eliminates SI vs. 
English units conflicts. 


Viewing the Picture 


After you select a subject and title, you can view the picture of the 
problem—but only if the title has a picture. 


To see the picture, press FIG. While the picture is displayed, you 
can do the following: 


m Press #F 17 to store the picture in PICT, the graphics memory— 


then you can use (PICTURE) to view the picture after leaving the 


Equation Library catalogs. 
m Press the menu keys or (ENTER) to show other equation information. 


For information about displaying and manipulating graphics objects, 
see chapter 9, “Graphic Objects.” 
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Using the Multiple-Equation Solver 


The Equation Library starts the Multiple-Equation Solver 
automatically if the equation set contains more than one equation. 
However, you can also start it up explicitly using your own set of 
equations (see “Defining a Set of Equations” on page 25-8). 


When the Equation Library starts the Multiple-Equation Solver, it 
first stores the equation set in EQ and stores a copy of the equation 
set, the list of variables plus additional information in Mpar. Mpar 

is then used to set up the Solver menu for the current equation set. 
(Note that, although you can view and edit EQ directly like any other 
variable, Mpar can only be edited indirectly (executing commands 
that modify it) as it is structured as library data dedicated to the 
Multiple Equation Solver application.) 


The following table summarizes the actions for the solver menu keys. 


The key shows additional menu labels. 


Solver Menu Keys 


Action 


Operation 


Creates variable if necessary, stores 
value in variable, and makes 
variable user-defined. If the value 
has no units, the units of the 
previous value are appended, if any. 


Store value 


Creates variable if necessary, solves 
for value of variable, and makes 
variable not user-defined. 


Solve for value 


Recalls value of variable to stack. 


©) 
(4) 
Recall value ®© 
(a2) 


Undefine all ALL Makes all variables not 
user-defined, but does not modify 
their values. 
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Solver Menu Keys (continued) 


Operation Key Action 


Solve for all (4) ALL Creates variables if necessary and 
solves for all variables not 
user-defined (or as many as 


possible). 

Progress catalog | (œ) ALL Shows information about last 
solution. 

User-defined HESE Sets states to user-defined for 
variable or list of variables on the 
stack. 


Calculated 


Sets state to not user-defined 
(calculated result) for variable or 
list of variables on the stack. 


The menu labels for the variable keys are white at first—they change 
during the solution process as described below. 


Because a solution involves many equations and many variables, 

the Multiple-Equation Solver must keep track of variables that are 
user-defined and not defined—those it can’t change and those it can. 
In addition, it keeps track of variables that it used or found during the 
last solution process. 


The menu labels indicate the states of the variables. They’re 
automatically adjusted as you store values and solve for variables. You 
can check that variables have proper states when you supply guesses 
and find solutions. 


Notice that # marks the variables that were used in the last solution— 
their values are compatible with each other. Other variables may not 
have compatible values because they weren’t involved in the solution. 
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Meanings of Menu Labels 


Label Meaning 


Value z0 not defined by you and not used in the 
last solution—it can change in the next solution. 


Value z0 not defined by you, but found in the last 
solution—it can change in the next solution. 


BO Value z0 defined by you, but not used in the last 
solution—it can’t change in the next solution 
(unless you solve for only this variable). 


alle Value z0 defined by you and used in the last 
solution—it can’t change in the next solution 


(unless you solve for only this variable). 


Defining a Set of Equations 


When you design a set of equations, you should do it with an 
understanding of how the Multiple-Equation Solver uses the equations 
to solve problems. 


The Multiple-Equation Solver uses the same process you’d use to solve 
for an unknown variable—assuming you weren’t allowed to create 
additional equations. You’d look through the set of equations for one 
that has only one variable that you don’t know. You’d use the HP 48 
root-finder to find its value. Then you’d do this again until you’ve 
found the variable you want. 


You should choose your equations to allow likely unknown variables to 
occur individually in equations. You must avoid having two or more 
unknown variables in all equations. You can also specify the equations 
in an order that’s best for your problems. 


For example, the following three equations define initial velocity and 
acceleration based on two observed distances and times. The first two 
equations alone are mathematically sufficient for solving the problem, 
but each equation contains two unknown variables. Adding the third 
equation allows a successful solution because it contains only one of 
the unknown variables. 
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My=uta- h 
T2 = w +4: t 
(to — t1) = a- (to — t) 


To create more robust equations, you can include functions that 
ensure proper and faster calculations—for example CONST and 
TDELTA, UBASE, EXP, and IFTE. See the HP 48G Series Advanced 
User’s Reference for details and examples. 


If your equations use any of the following functions, their variables 
won’t necessarily be detected by the Multiple-Equation Solver: E, Í. 
ô, |, QUOTE, APPLY, TVMROOT, and CONST. 


The list of equations in FQ may contain menu definitions, but those 
definitions are ignored by MINIT when it creates Mpar. However, you 
can reorder the menu labels using MITM, described under “Changing 
the Title and Menu” later in this chapter. 


To create a set of equations for the Multiple Equation Solver: 


1. Enter each equation in the set onto the stack. 

2. Press (A) to begin the Interactive Stack and then move the cursor 
up to the level containing the first equation you entered. 

3. Press +L IST to combine them into a list. 

4. Press 7) (a) E @) Q (or ()(GOLVE) FOOT () Eu) to 
store the list into the EQ variable. 

5. Press ()(EQUIB) MES MINIT to create Mpar and prepare the 
equation set for use with the Multiple Equation Solver. 

6. Press MUL. to launch the solver with the new set of equations. 


To change the title and menu for a set of equations: 


1. Make sure the set of equations is the current set (they are used 
when the Multiple Equation Solver is launched). 

2. Enter a text string containing the new title onto the stack. 

3. Enter a list containing the variable names in the order you want 
them to appear in the menu. Use a "" to insert a blank label. You 
must include all variables in the original menu and no others, and 
you must match uppercase and lowercase names properly. 


4. Press (@)(EQUB) MES MITH. 
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interpreting Results from the Multiple Equation Solver 


The Multiple-Equation Solver solves for variables by repeatedly 
looking through the set of equations for one that contains only one 
variable that’s “unknown” (not user-defined and not found by the 
solver during this solution)—then it uses the HP 48 root-finder to find 
that value. It continues eliminating “unknown” variables until it solves 
for the variable you specified—or until it can’t solve for any more 
variables. Each time the Multiple-Equation Solver starts solving for a 
variable, only the variables with black menu labels are “known.” 


During the solution process, the Multiple-Equation Solver shows the 
variable it’s currently solving for. It also shows the type of root found 
by the HP 48 root-finder (zero, sign reversal, or extremum)—or the 
problem if no root is found (bad guesses or constant). (You can 
watch the iterations if you press any key except during the 
root-finding process. For more information about the root-finder, see 
chapter 18. 


The following messages indicate errors in the problem setup: 


a Bad Guesstesi. Units may be missing or inconsistent for a 
variable. For a list of guesses, at least one of the list elements must 
have consistent units. 


a Too Mary Unknowns. The solver eventually encountered only 
equations having at least two unknowns. Either enter other known 
values, or change the set of equations—whichever is appropriate for 
your problem. See “Changing the Equations” later in this chapter. 


a Conatant? The initial value of a variable may be leading the 


root finder in the wrong direction. Supply a guess in the opposite 
direction from a critical value—if negative values are valid, try one. 


Checking Solutions 


The variables having a # mark in their menu labels are related for the 
most-recent solution—they form a compatible set of values satisfying 
the equations used. The values of any variables without marks may 
not satisfy the equations because those variables weren’t involved in 
the solution process. 


If any solutions seem improper, check for the following problems: 
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Wrong units. A known or found variable may have units different 
from those you assumed. These are global variables. If the variable 
existed before this calculation, then its unit system (SI or English) 
takes priority. To correct the units, either purge the variables before 
solving the equation, or enter the specific units you want. 


No units. If you’re not using units, your implied units may not 
be compatible among your variables or with the implied units of 
constants or functions. The current angle mode sets the implied 
units for angles. 


Multiple roots. An equation may have multiple roots, and the 
solver may have found an inappropriate one. Supply a guess for the 
variable to focus the search in the appropriate range. 


Wrong variable states. A known or unknown variable may not have 
the appropriate state. A known variable should have a black menu 
label, and an unknown variable should have a white label. 


Inconsistent conditions. If you enter values that are mathematically 
inconsistent for the equations, the application may give results that 
satisfy some equations, but not all. This includes over-specifying 
the problem, for which you enter values for more variables than 
needed to define a physically realizable problem—the extra values 
may create an impossible or illogical problem. (The solution satisfies 
the equations the solver used, but the solver doesn’t try to verify 
that the solution satisfies all of the equations.) 


Not related. A variable may not be involved in the solution (no # in 
its menu label), so it’s not compatible with the variables that were 
involved. 


Wrong direction. The initial value of a variable may be leading the 
root finder in the wrong direction. Supply a guess in the opposite 
direction from a critical value—if negative values are valid, try one. 
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Using the Constants Library 


The Constants Library contains a collection of common physical 
constants and quantities. You can use them in equations and 
programs. (Several of these constants are used by the Equation 
Library.) The following table lists them in the order they appear in 
the Constants Library. 


Constants Library 


Name Description Value (SI) 
NA Avogadro’s number 6.0221367E23 gmol7! 
k Boltzmann constant 1.380658E—23 J/K 
Vm Molar volume 22.4141 l/gmol 
R Universal gas constant 8.31451 J/(gmol-K) 
StdT Standard temperature 273.15 K 
StdP Standard pressure 101.325 kPa 
o Stefan-Boltzmann 5.67051E—8 W/(m?-K*) 
constant 
c Speed of light in vacuum | 299792458 m/s 
£0 Permittivity of vacuum 8.85418781761E—12 F/m 
pO Permeability of vacuum 1.25663706144E—6 H/m 
g Acceleration of gravity 9.80665 m/s? 
G Gravitational constant 6.67259E—11 m3/(s?-kg) 
h Planck’s constant 6.6260755E—34 J-s 
hbar Dirac’s constant 1.05457266E—34 J-s 
q Electron charge 1.60217733E—19 C 
me Electron rest mass 9.1093897E—31 kg 
qme q/me 175881962000 C/kg 
mp Proton rest mass 1.6726231LE—27 kg 
mpme mp/me 1836.152701 
a Fine structure constant 0.00729735308 
@ Magnetic flux quantum 2.06783461E—15 Wb 
F Faraday constant 96485.309 C/gmol 
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Constants Library (continued) 


Name Description Value (SI) 
Roo Rydberg constant 10973731.534 m7! 
a0 Bohr radius 0.0529177249 nm 
uB Bohr magneton 9.2740154E—24 J/T 
uN Nuclear magneton 5.0507866E—27 J/T 
AO Photon wavelength (ch/e) | 1239.8425 nm 
f0 Photon frequency (e/h) 2.4179883E14 Hz 
Ac Compton wavelength 0.00242631058 nm 
rad 1 radian 1 radian 
twor 2r radians 6.28318530718 radians 
angl Z in trig mode 180° 
c3 Wien displacement 0.002897756 m-K 
constant 
kq k/q 0.00008617386 J/(K-C) 
€0q €0/q 55263469.6 F/(m-C) 
qe q*e0 1.4185979E—30 F-C/m 
esi Dielectric constant 11.9 
€0X SiO» dielectric constant 3.9 


Reference intensity 


To view the Constants Library: 
m Press (4)(EQ LIB) COLIE COHNLT. 


0.000000000001 W/m? 


To view the value of a particular constant in full: 


1. While viewing the Constants Library, move the highlight to the 
desired constant. You may either use the (A) and (¥) arrow keys or 
press (a) followed by the first character of the constant. 

2. Press VALUE and UH ITS (if necessary) so that the = is displayed 
in the menu label in order to display the numerical value and units 
of the constant. 

3. Press (ENTER). If the constant value is too long to be fully 
displayed in a single line, then you will see it displayed more fully 
on a screen by itself. 
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To put a constant from the library on the stack: 


1. Press )(EQ LIB) COLITE COLI to open up the Constants 
Library. 

2. Move the highlight to the desired constant. 

3. Optional: If you want the units included be sure that the æ is 
showing in the LIMIT label. 

4. Press #27R QUIT. 


To include a constant in an algebraic expression: 


1. Begin entering the algebraic into the command line. 

2. Press ()(EQ LIB) COLLIE CONST. You will see Ct 
into the algebraic. 

3. Type in the symbol for the constant. Note that the value returned 
by the CONST function may or may not include units depending 


on how you have currently set WHITS. 


HTE» entered 


Minehunt Game 


The Minehunt game is a battlefield adventure. You start at the 
upper-left corner of an 8 x 16 battlefield grid. Your mission is to 
travel safely to the lower-right corner, avoiding invisible mines along 
the way. The game tells you how many mines are under the eight 
squares adjacent to your position. 


To play Minehunt: 
a Press @)EQUB)UTILS MIHE 


æ Use the number keys or arrow keys to move. The “corner” number 
keys allow you to move diagonally. Exit at any time by pressing 


(CANCEL). 
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User-Defined Units 


The Equation Library provides four user-defined units: “gmol” 
(gram-moles, mol), “Ibmol” (pound-moles, approximately 454 

mol), “rpm” (revolutions per minute, 1/min), and “dB” (decibels, 
dimensionless). You can use their menu keys as typing aids. To fully 
use these units, add them to the custom menu. (User-defined units are 
described on page 10-14.) 


Example: Put the Equation Library units in a custom menu. 


Step 1: Enter this list of unit objects (one for each unit): 


cel 


es 
zi amol iL 


3 


(VED MEQ UB) UTILS 
œQ eral 

1@C LENG 

1@MOQ FFM 

1@O tE 


Step 2: Store this in the custom menu and display the menu. 
(Custom menus are described on page 30-1.) 


(4)(MODES) MENU MENU 


You get the custom menu at any time by pressing (CST). The following 
examples show how to use the user-defined units in the custom menu: 


m Press GĦHOE to add units to the number you’re entering or to 
append units to the unit numerator of the object in level 1. 

m Press (>) GHOL to append units to the unit denominator of the 
object in level 1. 


to convert the unit object in level 1 to “gmol.” 
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Time Management 


Using the Clock (Date and Time) 


When you display the clock, it appears in the upper-right corner of the 
display. It shows the current date and time in your choice of formats, 
shown in the table below. The formats also determine the way you 
enter dates and times in the command line. The following table 
illustrates how the clock shows 4:31:04 PM on February 21, 1994. 


p Clock Display Format Number Form 
Date: 
B22171394 | Month/day/year format 2.211994 
21.02.1394 |Day.month.year format 21.821954 
Time: 
GehiSis@4P |12-hour format 16. ala4 
i314 |24-hour format 16.5164 


To display the date and time: 


1. Press (¢>)(MODES). 

2. Move the highlight to the CLOCK field and press #lHP. to put a 
check-mark in the field. 

3. Press: OE 
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To change the date or time: 


1. 


Press (@)(TIME) (@) GE to open the SET TI 
dialog. 


SET TIME AND DATE RS 


TME = AE 46:27 AM 
DATE: 4/36/93 MeDeY 


ENTER HOUR 
EDIT chon: | eee KANiLI 0E 


. Highlight the hours field and type the hour, minutes and seconds, 


pressing (ENTER) after each. 


Optional. If you want the clock to report the time using 24-hour 
format, press until 24—hr is displayed. 


. Highlight the first date field and type the day, month and year in 


their respective fields, pressing after each. The year can be 
from 1991 through 2090. 

Optional. If you want the clock to report the date using 
day-month-year format, press until P.P. Y is displayed. 


. Press 0 to confirm the changes and return to the stack. 


Setting Alarms 


You can set two types of alarms, which perform different actions when 
they come due: 


Appointment alarm. This displays the message you specified when 
you set the alarm. It also sounds a sequence of beeps for about 15 
seconds—or until you press a key. You’re expected to acknowledge 
an appointment alarm after it comes due. 


Control alarm. This executes the program or other object you 
specified when you set the alarm—no other action occurs. You don’t 
acknowledge a control alarm. 


When you set an alarm, it’s saved in the system alarm list, where it 
can be reviewed and edited (“browsed”) later. 
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To set an appointment alarm: 


1. Press G)CIME)(¥) GE to open the SET ALA 


Se SET ALARM Š 
MESSAGE: 
TIME: 9:31:66 AM 
DATE: i? 3794 
REPEAT: None 


ENTER "MESSAGE" OR & ACTION > 
EuT TRAN] Dk] 


2. Press ()(_*), type in the message you want displayed when the 
alarm comes due and press (ENTER). 

3. Enter the time (hours, minutes, seconds) and the format (AM, PM, 
or #4—hr) of the alarm. 

4. Enter the date of the alarm. It is shown in the current date format 
(either ©. Ma or MD). 

5. Highlight the REPEAT field and enter the number and period of the 
repeat interval. For example, press 15 (a)D to enter 15 
(aus as the repeat interval. Press 0 for a non-repeating 
alarm. 

6. Press GE toset the alarm and return to the stack. 


To set a control alarm: 


1. Press (JAME) (WY) OE to open the SET ALARM dialog. 

2. Enter the program or other object you wish to execute when the 
alarm comes due into the MESSAGE: field. 

3. Enter the time and date for the alarm. 

4. Highlight the RE T field and enter the number and period of the 
repeat interval. Press 0 for a non-repeating alarm. 

5. Press GE — toset the alarm. 
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Responding to Alarms 


When an appointment alarm comes due, the () annunciator turns 
on, the beeper sounds at short intervals for about 15 seconds, and the 
alarm message is displayed. If you press a key during the beeps, the 
alarm is acknowledged, and the current appointment is deleted. 


If you don’t acknowledge an alarm during the beeps, the beeper stops 
and the message is cleared from the display. A repeating alarm is 
normally automatically rescheduled. A nonrepeating alarm becomes 
“past due,” but not deleted—the (+) annunciator remains on to show 
you have a past-due alarm to respond to. 


If you have several past-due alarms, you can view them by pressing 
CME) GE- . Press FORG to delete an alarm. Each time you 
press (4)(TIME) ALEM ACE , the oldest past-due alarm is deleted. 
The (e) annunciator turns off when no past-due alarms remain. 


To respond to an appointment alarm: 
m While the alarm is beeping, press any key, such as (CANCEL). 


or 

m After the beeping stops, the message appears. Press ()(TIME) 
ALEM AECE. (You can then press to return to the 
stack.) 


To respond to a control alarm: 


ma Do nothing. You don’t acknowledge a control alarm when it comes 
due— it’s automatically considered to be acknowledged. When a 
control alarm comes due, a copy of the alarm indez is returned to 
level 1, then the specified object is executed. The alarm index is a 
real number that identifies the alarm based on its chronological 
order in the system alarm list—you can use it with programmable 
alarm commands (described in the HP 48G Series Advanced User's 
Reference). 


To acknowledge all past-due alarms at once: 

u Press (4)(TIME) ALAR ACER. 

It’s possible for a repeating alarm to have a short enough repeat 
interval that it reschedules and executes faster than you can delete it 


from the alarm list. This may occur if you mistakenly set a repeating 
appointment alarm for a very short interval. It may also occur in the 
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case of a control alarm that executes a program to take measurements 
at short intervals. 


To recover from a short-interval repeating alarm: 


a Press the and (4) keys simultaneously, then release them. This 
keystroke sets a state in the calculator that cancels the rescheduling 
of the nert due alarm (presumably the short-interval repeat alarm). 
When that alarm comes due—or when you press the next key— 
the special “no-reschedule” state of the calculator is canceled so 
future alarms aren’t affected. Because pressing a key cancels the 
“no-reschedule” state, you should wait until the alarm comes due 
before pressing any keys. 


To save or not save non-repeating alarms you acknowledge: 


m To delete alarms when they’re acknowledged, press 44 
(MODES) FLAG CF. This is the default setting. All 
control alarms (nonrepeating or repeating) that come due are always 
saved in the system alarm list, regardless of the setting of Flag —44. 

m To save alarms when they’re acknowledged, press 44 
(4)(MODES) FLAG &F_ . Past-due occurrences of repeating 


alarms are not saved. 


Viewing and Editing Alarms 


To view, edit, or delete an alarm: 


a Open the Browse alarms... dialog box. @)GIME) GF All 
existing alarms are displayed. 

a To edit an alarm, highlight the alarm you want to edit and press 
ERIT. 

m To delete an alarm, highlight the alarm you want to delete and press 
PIRG. 


Use “HEL to create multiple alarms (after you create an alarm you 
return to the ALARMS dialog). 
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To change the way repeating alarms work: 
m To a delete and reschedule them, press 43 


(4) HODES) F 


a To make them past due and not reschedule them, press 43 ŒA) 


(MODES) FLAG SF 
To control the alarm beeper: 
m To enable the alarm beeper, press 57 @) (MODES) FLAG 


m Tos suppress the alarm beeper, press 57 (4)(MODES) FLAG 


Pe mt 
one 
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Transmitting and Printing Data 


Transferring Data Between Two HP 48s 


To transfer objects from one HP 48 to another: 


1. Line up the infrared ports by lining up the 4 marks (near the 
Hewlett-Packard logo just above the display). The calculators 
should be no farther apart than 2 inches. 


lel 
Si 
35 
ze 
on 
aa 


T Parkano 


2. Receiver. 
a. Change to the directory where the objects are to be stored. 


b. Press (>)QZ0). 


iP 46 from the menu and press = DE 


3. Sender. 
a. Press (¢>)(/0). 
b. Select = HE 48... from the menu and press = OF 
c. Press © * and select the names of the objects to be 


transferred into the HAME field. Press . OE 


d. Press |! 
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Printing 

With certain exceptions, printing commands print objects according to 
these guidelines: 

a An object is printed with its delimiters. 


m An object that doesn’t fit in one line of output continues on the 
following lines. 


m An array object is printed in expanded form. 


When you print an array in expanded form, each row and column is 
labeled. For example, the 2 x 3 array 


be 223 
4 5 6 


Array £ 2 3 3 <~ Array dimensions 
Row number —> Row 1 
1] 1 
Column number { 21 2 
| 31 3 


is printed like this: 


Row 2 
1] 4 
215 
3] 6 


m A graphics object is printed in its stack form. 


You can perform any printing operation with any compatible printer— 
with these exceptions: 


m Special characters in the HP 48 character set may not print properly 
on a serial printer. 


m You can’t print a graphics object or the display on a serial printer. 
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Setting Up the Printer 


To set up the HP 822408 infrared printer: 


1. Place the HP 48 and the printer on a flat surface. Aim the A 
(near the Hewlett-Packard logo just above the display) toward 
the window on the printer. Keep them within 18 inches (45 
centimeters). 

2. Press 34 (4)(MODES) FLAG CF to make sure flag —34 
is clear (its default state). 

3. If you previously pressed ți 


BE 
PRTPAR—press (e) (70) FE 


EK for any reason, reset the variable 
THT FRTPA RESET 


To set up a serial printer: 


1. Connect the 9-pin end of an HP 48 serial cable to the serial printer. 
If necessary, use a 9-pin to 25-pin adapter. 

2. Keep the HP logo on the 4-pin connector facing up, then plug the 
cable into the HP 48. You should feel it lightly snap into place. 

3. If your printer uses XON/XOFF handshaking: Press ()(1/0) 
SERIA OFEHI T-0 CLOSE to create JOPAR. Then press 
(>) [OF AR (SEDIT) and change the fourth number to 1— 
for example, 1 96984813 1 3. Press (4) OFAR. 

4. If your printer requires an end-of-line sequence other than 
carriage-return/line-feed, press ()(/0) FEI to create 
PRTPAR, then edit the end-of-line parameter (the fourth element 
in the PRTPAR list). 


Printing Tasks 


To print an object via infrared: 


1. Be sure that the printer is setup properly and turned on. 


2. Press PO MMA «GE to open the FEIHT form. 
3. If necessary, press (A) to change the communications port to 


Pane : 
infrared, 
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4. Press EHO 
and press 


PORT: 
OBJECT: 
—DBL-SPACE DELAY: 1,8 LINEF 


Infested 


CHOOSE PRINT PORT 
enone tt [PRINT 


The Infrared PRINT Screen 


move the highlight to a variable you wish to print 


5. Optional: Adjust any of the printing parameters that you wish. 


DE 


6. Press FETHT. 


than 6.9) the HP 48 waits between sending lines 
of information to an infrared printer. To optimize 
printing efficiency, set the delay just longer than 
the time the printhead requires to print one line of 
information (default is 1.8 seconds). 

Normally (check-mark on), each print command 
completes data transmission by automatically 
executing the CR (carriage right) command, which 
tells the printer to print the data currently in its 
buffer and leave the print head at the right end 

of the print line. Alternatively (check-mark off), 
you can suppress the automatic CR command 

and accumulate several print commands in the 
print buffer, which are then printed only when you 


manually execute CR (D0) FR 


To print a variable via the Serial Interface cable: 


1. Be sure that the printer is set up properly and that the cable is 
properly connected. 


2. Press (*)(1/0) (W) (¥) (7). EE to open the FR INT form. 
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PORT: 
OBJECT: 

_DBL-SPACE HLAT: Meni] of LINEF 
Bale: SERGE PARITY: None LEM: 8G 


ENTER OBJECT(S) TO PRINT 
EDIT [ehon || PRINT 


The Wire PRINT Screen 


Wire 


3. If necessary, press (A) to change the communications port to 
Hire. 
4. Press HI 
and press 
. Optional: Adae? any of the printing parameters that you wish. 
DEL- SPACE Put a check-mark to produce double-spaced 
output. 
LATE Choose which of four different character 
translation options you wish to use. See page 
27-15 for more details about these options. 
LIHEF Normally (check-mark on), each print 
command completes data transmission by 
automatically executing the CR (carriage right) 
command, which tells the printer to do a 
carriage-return/line-feed. Then the printer prints 
the data currently in its buffer. Alternatively 
(check-mark off), you can suppress the automatic 
CR command and accumulate several print 
commands in the print buffer, which are then 
printed only when you. manually execute CR 
(UO) Pe 
BALID Enter or choose the transfer speed. The printer 
and HP 48 must have the same setting. 
Enter or choose the parity setting for the transfer. 
The printer and HP 48 must have the same 
setting. 
LEH: Enter the printer’s line length (in characters). 


move the highlight to a variable you wish to print 


or 
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To print the object in level 1: 


1. Be sure that printer and HP 48 are properly set up for printing. 
2. If the port and print parameters are set properly, press (=)(/0) 
FEI 
3. If you need to change the port and print parameters, then: 
a. Pres œO MNN GE 
b. Press TALE ME to enter the object on level 1 of the 
stack. 
c. Set the port and print parameters as necessary (see the previous 
two procedures for more details). 
d. Press FRIHT. 


To print the current display image: 


1. Be sure that printer and HP 48 are properly set up for printing. 
2. Press @)(Z0O)(V)(W) GE . The display you see after pressing 
(ik is the display that was printed. (If the printing does not 
occur, you may need to change the communications port or other 
print parameters and try again.) 

3. If you cannot select Print display without changing or altering 
the display you wish to print, prepare the display the way you wish 
and press and hold down (ON), press and release G), and release 
(ON). 


To print all objects on the stack: 
m Press @)(/O)FRIHT FRET. 
To print a group of variables: 


1. Set the port and print parameters as needed. 

2. Put the list of variables on level 1 of the stack. 

3. Press 4)(/0) FEINT FRYAR. Both the name and contents of 
each variable will be printed. 
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Transferring Data Between the HP 48 and a 
Computer 


Preparing the Computer and the HP 48 


Use a Serial Interface Cable to connect the HP 48 and the computer. 
The cable is included with the Serial Interface Kit, available from 


Hewlett-Packard. (For information about these products, see your HP 
dealer.) 


To connect a computer and HP 48: 


1. Connect the computer end of the serial cable to the serial port on 
the computer. If necessary, use a connector adapter. (The following 
diagram shows the wiring used by the PC version of the Serial 
Interface Cable and its adapter. If you need more information, 
consult your computer documentation.) 


25 — pin 27 « 


9 — pin 


GND 
TX 


RX 
SHIELD 


Serial Interface Cable and Adapter (PC Version) 
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2. Keep the HP logo on the 4-pin connector facing up, then plug the 
cable into the HP 48. You should feel it lightly snap into place. 


Not quite flush 


To set up for HP 48-to-computer transfers: 


1. Make sure that the serial cable is properly connected to the 
computer and to the HP 48. 
2. HP 48. Press œO AMA) E to view the TRANSFER form. 


PORT: Wire TYPE: Kermit 
NAME: 
FMT: ASC RLAT: Hewl CHK: 3 


BAUD: 3GG@ PARITY: None _OvRW 


ENTER NAMES OF VARS TO TRANSFER 
EDIT JCHOOS] | RECM EGET END | 


The Wire TRANSFER Screen 


3. HP 48 Set the I/O parameters: 


PORT: Select the communications port (usually Hire for 
transfers between the HP 48 and a computer). 

TYPES Select the transfer protocol, either Kermit or 
roder. 

FHT: Select the transfer format, either ASCII or Binary 


(only available for Kermit). 
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Select one of four character translation options 
(only available for Kermit). See page 27-15 for 
more details. 

Select one of three error detection protocols (only 
available for Kermit). 

Enter or choose the transfer speed. The setting 
must match that of the computer. 

pya Enter or choose the transfer parity (only available 
for Kermit). The setting must match that of the 
computer. 

Put a check-mark here if you want received 
objects to overwrite objects with the same name. 
When unchecked, name conflicts are resolved by 
adding number extensions to the incoming object. 


Using Kermit 
By default, the HP 48 uses Kermit file transfer protocol to transfer 

data and to correct transmission errors. The HP 48 also provides 
commands for XMODEM and other non-Kermit serial data transfers, 

such as sending data to a serial printer or instrument. Kermit protocol 27 
was developed at the Columbia University Center for Computing 

Activities and is available for many computers. 


Transferring Variables with Kermit 


To transfer data to and from a computer using Kermit, the computer 
must be running a program that has Kermit protocol. If you want 
additional information on Kermit protocol, the following books are 
available or can be ordered in many bookstores: Using MS-DOS 
Kermit by Christine M. Gianone, Digital Press, 1990, and KERMIT, 
A File Transfer Protocol by Frank da Cruz, Digital Press, 1987. 


To transfer variables from the HP 48 to a computer: 


1. Computer. Change to the directory where the objects are to be 
stored. 

2. Computer. Run the program that has Kermit. Set the transfer 
format to Binary or ASCH to match the current HP 48 setting. 
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Binary is much faster, but if you want to edit objects on the 
computer use ASCII. 


- Computer. Execute the Kermit command to make it the server, 


such as SERVER. 

HP 48. Press @)(/0) (4) (4) GE 

HP 48. Enter or choose the names of the HP 48 variable or 
variables to be transferred. Press CHOOS GE to browse the 
current directory, put a check-mark next to each variable you wish 
to transfer to the computer. If necessary, move to a different 
directory to choose variables (although you may only transfer 
variables from a single directory at a time). Press & to enter 
the list of names in the TRAMSFER form. 

HP 48. Make sure that the I/O parameters are properly set up for 
the transfer (see page 27-8 for details). 


. HP 48. Press SEHD . 
. HP 48. Terminate server mode by pressing ()(/0) = 


FALHIS. 


To transfer files from a computer to the HP 48 using the HP 48: 


1. 


eo 


Computer. Run the program that has Kermit. Set the transfer 
format to Binary or ASCII to match the current HP 48 setting. 


. Computer. Execute the Kermit command to make it the server, 


such as SERVER. 

HP 48. Press HOAD GE. 

HP 48. Press CHOO (Y) OF to bring up a listing of the 
computer’s current directory. (Note that this will only work for 
PC-compatible computers.) Select the files you wish to transfer 
by placing check-marks next to their names. You may switch 
directories by pressing CHOG, just as with the Variable Browser, 
if the files are located in another directory. Press iE after 
all files are selected to return the list to the HAME: field in the 
TRANSFER form. 


. HP 48. Make sure that the I/O parameters are properly set up for 


the transfer (see page 27-8 for details). 


. HP 48. Press EGET. 


HP 48. ‘Terminate server mode by pressing (D) (0) = 
EIHILT. 
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To transfer a file to the HP 48 from a computer using the computer: 


1. Computer. Change to the directory where the files are to be stored. 

Computer. Run the program that has Kermit. 

HP 48. Press HOAD UE 

HP 48. Make sure that the I/O parameters are properly set up for 

the transfer (see page 27-8 for details). 

5. HP 48. Press REC 

6. Computer. Execute the Kermit command to send the file, such as 

SEND file. 

7. Optional: To transfer additional files, repeat steps 5 and 6. 

8. Computer. To end the session, execute the Kermit command to 
shut down the server, such as FINISH. 


Pe Ger Bo 


Choosing and Using File Names 


The naming conventions for computer files are different from those for 
HP 48 variables. 


When the HP 48 receives a file from a computer, certain difficulties 
may arise due to the computer file name. 


a If the file name contains characters not allowed in a variable name 
(such as AE# or €ABC3), the HP 48 terminates the transfer and 
sends an error message to the computer. 


a If the file name matches a built-in command (such as SIH or DUF), 
the HP 48 appends a number extension to the name (such as 
SIM. 1). 


m If the name matches a variable name in the current directory and 
flag —36 is clear (to protect existing variables), a number extension 
is added to the name (such as HAME. 1). 


When the HP 48 sends a variable to a computer, its name may be 
incompatible with the naming conventions of the computer software. 
Transferring such a file can result in a transfer error. (You can avoid 
this problem by renaming the variable before sending it.) 
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Backing Up HP 48 Memory 


You can back up and restore the contents of the entire HOME 
directory in a file on your computer. The HOME directory includes all 
variables, user key assignments, and alarms. You can also include all 
flag settings if you want. 


The following steps assume you’ve prepared the computer and HP 48 
for data transfer—see “Preparing the Computer and HP 48” on page 
27-7. 


To back up all user memory to a computer file: 


Caution While backing up memory, make sure the ticking 
clock is not in the display. If the clock is in the 
D display, it may corrupt the backup data. 


1. Computer. Execute the Kermit command to set up binary transfer, 
if available. 

2. Computer. Execute the Kermit command to make it the server, 
such as SERVER. 

3. HP 48. Optional: To back up flag settings too, press (A) (MODES) 
FLAG RCLE , enter a flag-variable name (with | 
delimiters), and press (STO). 

4. HP 48. Enter the tagged object : 10! name on the stack, where 
name is the name of the file to be created on the computer. 


5. HP 48. Press ()(MEMORY) AR CHI. 
6. HP 48. To end the session, press (@)(I/0) SEE FIKIS. 


ARCHIVE always uses binary transfer, regardless of the 
ASCI/Binary setting on the HP 48. 


Caution Use the RESTORE command with care; restoring 
backed up user memory completely erases current 
user memory and replaces it with the backup copy. 
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To restore HP 48 user memory from a computer file: 


1. Transfer the computer file to an HP 48 variable using one of the 
data transfer methods discussed above. Make sure that the transfer 
mode is Binary. 

2. HP 48. Enter the received variable name (with ' delimiters) onto 

the stack and press (>) (RCL) to recall the backup object. 

. HP 48. Press ()(MEMORY) (NXT) RESTO. 

4. HP 48. Optional: To restore flag settings previously saved, enter 
the flag-variable name (with ' delimiters), press (@)(RCL), and 
press (#)(MODES) FLAG STOR. 

Example: To back up MEMORY into a file named AUG, enter the 
tagged object § UGI as the backup name. Then, if 
you later sebrieve e this data to the HP 48, you can enter 
‘ALIGL' and press (@)(RCL) to get Backup HOMEDTR on 
the stack—ready for the RESTORE command. 


ww 


Sending Kermit Commands 


You can use an HP 48 to send Kermit commands to a Kermit server— 
another HP 48 or a computer. If the HP 48 is a server, you can send 
Kermit commands to it (although it only responds to GET (KGET) 
SEND, REMOTE DIR, REMOTE HOST, FINISH, and LOGOUT). 
The following steps assume the receiving device is already set up as a 
server. 


To send a Kermit command from an HP 48: 


1. Enter the command as a string (with " “ delimiters). 
2. Enter the packet type as a string (with " " delimiters). 


3. Press ()(/0O) SEVE PRT 


The server sends one of the following responses to the PKT command: 


a An acknowledging message. The reply to the packet is returned as 
a string to level 1—an empty string is returned if no response is 
appropriate. 


m An error packet. The HP 48 briefly displays the contents of the 
error packet. To retrieve it, press (4)(i/0) EERE . 


Example: To request a directory listing, enter "D" and “G and 
press FET . The directory is returned as a string. 


H 
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Using XMODEM 


The XMODEM protocol built into the HP 48 doesn’t perform any 
CRC checking, but it will work with a computer-based XMODEM 
program that does. In this situation, you may have to wait a few 
moments before the computer’s program gives up trying to perform 
CRC checking and reverts to plain XMODEM. 


To transfer a variable to a computer using XMODEM: 


1. HP 48. Press œO (@)(@) 0E to open the TEAHSFER form. 

2. HP 48. Set the port to Hire, the type to “Hoden, and make sure 
the baud rate matches that of the computer. 

3. HP 48. Highlight the HAME: field, press CHOTE to select a 
variable, and enter it. 

4. Computer. If necessary, move to the directory where the variable is 
to be stored, start the XMODEM program and select Receive. 

5. Computer. Enter the filename, and start Receive. 

6. HP 48. Press SEHD . 


To transfer a variable from a computer using XMODEM: 


1. Computer. Move to the directory where the variable is stored. 
2. Computer. Start the XMODEM program. 
3. HP 48. Move to the directory where you want to put the incoming 


variable and then press ()(/0) (4) (4) GE to open the 
TEAHSFER form. 


- 4. HP 48. Set the port to Hire, the type to XModem, and make sure 


the baud rate matches that of the computer. 

5. HP 48. Type in a name for the variable to be received. Put a 
check-mark in the (FL! field if you want to overwrite a variable 
with the same name. 

6. HP 48. Press KECY. 

7. Computer. Start Send. 
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Using Other Serial Protocols 


You can send and receive data and commands with serial devices that 
don’t use Kermit protocol, such as serial printers and instruments. 
You do this using the general-purpose serial I/O commands. 


To review the current HP 48 I/O parameters: 


a Press (4)((20) IGFAR. If the parameters aren’t displayed, press 
HFA. 


To change HP 48 I/O parameters: 


1. Type in -58 and press ()(MODES) FLAGS iF. This makes 
the current settings visible while you change them. 

2. Press (0/0) LOFAR 

3. Change the desired parameter or parameters as follows: 

w Press TESH to select IF or Hire as the current 
communications port. 

m Type in either 1288, 2485, 4866, or 9495 and press BAUD to 
select the current transfer speed. 

m Type in either 1 (odd), Z (even), 3 (mark), 4 (space), or & 
(none) and press FARIT to select the current parity setting. 
Optionally, you may enter the negative of any of these options if 
you wish to use the parity setting only to transmit and disable 
parity-checking on receive. 

a If you are using ASCII transfer or printing, type in the number 
of the translation option you desire (see table below) and press 

TEAR. In the following table, “10 — 10,13” would be read 
“character 10 is translated into characters 10 and 13.” Selecting 
0 means you do not want any translation. 
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Summary of ASCII Data Translation Options 


Option 1 Option 2 Option 3 


Data Sent by HP 48 


10 — 10,18 10 — 10,18 10 — 10,13 


— 


128 — trans 128 — trans 


159 — trans 255 — trans 


Data Received by HP 48 


10,13 — 10 10,13 — 10 10,13 — 10 
trans — char trans — char 
“EGE — char HEE — char 


“LEG — char 255 — char 


ASCII Character Translations (Character Codes 128-255) 


HP 48 | HP 48 | Trans | | HP 48 | HP 48 | Trans | | HP 48 | HP 48 | Trans 
Code | Ch Code | Char Code | Char 
128 x “a 142 = “ao 156 T “FT 
129 x “a 143 a “a 157 ws “GL 
130 T my 144 + ee ede 158 E SEJ 
131 T ears 145 ; “a 159 ws SD 
132 t “5 146 a “Od 171 x wd 
133 = 5 147 E se 176 5 
134 Ẹ ho 148 à “Gri 181 o 
135 T hpi 149 a “Gh 187 $ 
136 a wad 150 KJ “G1 215 x TES 
137 z “aS 151 E “Gr 216 E SES 
138 3 SPS 152 ay “GS 223 E “Gb 
139 + REF 153 T “GE 247 + “i 
140 x * 154 te “Ghd nnn | other | nnn 
141 + tats 155 fy “AGEs 
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To transfer serial data with a non-Kermit serial device: 


1. Press (4)(/0) 1GFAF and set up the I/O parameters to match the 
serial device. If necessary, press THE to see the current 
settings. 

2. If the serial device uses receive or transmit pacing (XON/XOFF 
signals) during transfers, press 1OF AR (4)(EDIT): 

m To receive data using pacing, change the third number to 1. 
w To send data using pacing, change the fourth number to a for 
example, € y Press C) Torre 

3. Optional: Press i EHT to open the HP 48 
serial port. (This step isn’t necessary for most connections, but it 
prevents difficulties caused by the inability of certain devices to 
communicate with a closed port.) 

4. To send or receive serial data or commands, use the I/O menu keys 
for the desired operations—see the table below. 
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The I/O Menu—Serial I/O Commands 


Programmable 


Command 


Description 


SBER 


SRECV 


STIME 


SBRK 


Sends the string in level 1 without 
Kermit protocol. After the entire string 
is sent, 1 is returned to level 1. If the 
entire string failed to transmit, 0 is 
returned to level 1 and the unsent part 
of the input string is returned to level 
2—execute ERRM to see the error 
message. 

Receives the number of characters 
specified in level 1. For a successful 
transfer, the characters are returned to 
level 2 as a string, and 1 is returned to 
level 1. For an unsuccessful transfer, an 
empty or incomplete string is returned 
to level 2, and 0 is returned to level 1— 
execute ERRM to return the error 
message. (An unsuccessful transfer 
occurs if the characters contain a parity 
error, framing error, or overrun error, or 
if fewer than the specified number of 
characters are received before the 
timeout period expires, 10 seconds by 
default.) Characters are taken from the 
input buffer—no waiting occurs if you 
specify the number of characters in the 
buffer, which is returned by BUELE. 
Sets the serial transmit/receive timeout 
to the number of seconds specified in 
level 1. The timeout value can be from 
0 to 25.4 seconds. If you specify 0, the 
HP 48 waits indefinitely, which could 
result in excessive battery drain. 


Sends a serial BREAK signal. 
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The I/O Menu—Serial 1/0 Commands (continued) 


Key Programmable Description 
Command 
BUELE BUFLEN Returns the number of characters in the 
input buffer to level 2, and the error 
status to level 1 (1=no framing error or 
UART overrun, or 0=framing error or 
UART overrun). If 0 is returned to level 
1, the number of characters returned to 
level 2 represents the part of the data 
received before the error—you can use it 
to determine where the error occurred. 
Note Although XMIT, SRECV, and BUFLEN check 
i the send and receive mechanisms, the integrity of 
L} the data isn’t checked. One method to check the 


integrity of data transmission is for the sending 
device to append a checksum to the end of the data 
being sent, and for the receiving device to verify the 


checksum. 


OPENIO, XMIT, SRECV, and SBRK automatically open the 
IR/serial port using the current values of the first four JOPAR 
parameters (baud, parity, receive pacing, and transmit pacing) and the 
current IR/wire setting (set using IEH in the I/O SETUP menu). 
If you open the port, the input buffer can receive incoming data (up to 
255 characters), even before you execute SRECV. 
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Libraries, Ports and Plug-In Cards 


Port Memory and Plug-In Card Slots 


Port memory, also referred to as independent memory, is structured 
differently than user memory: 


m User memory can be subdivided into directories; port memory 
cannot. 

m Variables (global) in user memory are active and can move around 
physically in memory. Variables (port) in port memory are inactive 
and maintain a consistent physical location in memory. 


Port memory contains two kinds of objects: 


a Backup objects. Backup objects are regular objects converted to an 
“inactive” form suitable for port memory. 

m Libraries. Libraries are collections of named objects that act to 
extend the built-in command set. They must be stored in port 
memory and attached to a user directory in order to be usable. You 
can execute a named object from a library but not view or edit it, 
much as you can use a built-in command, but not edit it. 


To display the menu of objects stored in a port: 
1. Press ()(LIBRARY) FORTS . 


2. Press the menu key associated with the port you wish to view. 


To display the menu of libraries accessible from the current 
directory: 


a Press (GS) (CIERARY), 
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Port 0 


Port 0 is the only port memory available on all HP 48s. The memory 
for port 0 is taken out of user memory—so objects stored in port 0 
decrease the amount of user memory available. The size of port 0 is 
dynamic—it grows and shrinks to accommodate its contents. This 
diagram shows port 0 taking memory as necessary from user memory. 


7 
| Pn ee ie eee [ 

User | 0:NUM1 STO 

memory | Gee me Se ae E | 
CTO Port O | O:NUM1 | O:NUM1 


If you don’t have or don’t want to use plug-in cards, you can use port 
0 for storing backup objects and library objects. 


Card Slot 1 


The HP 48GX has two card slots. These card slots are not identical. 
Card Slot 1 can accept a plug-in card no larger than 128 KBytes. Any 
RAM memory on a card plugged into Card Slot 1 can be merged 

with built-in user memory to expand the amount of active memory 
available or it can remain as regular port memory. Card Slot 1 is 
identical to the card slots available on its predecessor, the HP 48SX. 
When port memory is used in Card Slot 1, it is designated as Port 1. 
The cards plugged into Card Slot 1 can be either RAM or ROM. 


Card Slot 2 


Card Slot 2 can contain a plug-in card up to 4 MBytes in capacity. 
(This translates into 4096 KBytes, of which only 3968 are accessible.) 
RAM memory on a card plugged into Card Slot 2 cannot be merged 
with built-in user memory. Instead, the port memory offered in Card 
Slot 2 is divided into distinct ports of 128 KBytes each. Thus, a 
1-MByte plug-in card offers Ports 2 through 9, each containing up to 
128 KBytes of backup objects and libraries. A 4-MByte plug-in card 
offers Ports 2 through 32. The cards plugged into Card Slot 2 can be 
either RAM or ROM. 
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Using Backup Objects 


The HP 48 uses a special object type, the backup object, to store 
backup data. A backup object contains another object, its name, and 
its checksum. 


Backup objects can exist only in port memory: 


m Port 0. 

a Port 1 if it contains RAM cards set up as port memory (that is, not 
merged). When you first install a card, it’s set up as port memory. 
(Port 1 doesn’t exist in the HP 48G.) 

m Ports 2 through 32 if they exist. (They don’t exist in the HP 48G). 


To back up an object onto a card: 


1. Put the object on the stack. 
2. Enter a backup identifier for the backup object to create—see 
below. 


3. Press (STO). 


4, Optional: Purge the original object in user memory. 


The STO command creates the backup copy using the port and name 
specified by the backup identifier—it has the form 


i port? name 


where port is the port number (0 through 32), and name is the name 
where the backup copy is stored. If you use port 1, it must not be 
merged with user memory. The name of the backup object can be 
different from the original name. 


You can back up an entire directory (and its subdirectories) in one 
backup object by putting the directory object on the stack and 
making a backup copy. 


To recall a port object to the stack: 


a Display the appropriate PORT menu, then press (f>) and the menu 
key for the object. 
or 

a Enter the backup identifier for the backup object and press 


(RL) 
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To evaluate a backup object: 


m Display the appropriate PORT menu, then press the menu key for 
the object. 
or 


m Enter the backup identifier for the backup object and press (EVAL). 


To evaluate several backup objects in a row, enter a list (with £ 3 
delimiters) containing the backup identifiers, then press for each 
backup object. 


To delete a backup object: 


m Enter the backup identifier for the backup object and press 
(4)(PURG). You can’t delete a backup object that you recalled to 
the stack—you get the Object im Use message. If you delete the 
object from the stack or store the object in a variable, then you can 
delete the backup object. 


To purge several backup objects simultaneously: 


1. Enter a list (with £ 3 delimiters) containing the backup identifiers. 


2. Press (4)(PURG). 


To search all ports for a backup object: 


1. Enter the backup identifier for the object—ezcept use & for the port 
number. (Press (œ) (|) (ENTER) to type &:.) 

2. Execute RCL, EVAL, or PURGE. Whenever you use the & 
“wildcard” character for the port number, the HP 48 searches ports 
in reverse numerical order beginning with the highest available (32, 
31,... , 2, 1, 0) and then main memory for the backup object—it 
uses the first occurrence of the name. 


Example: If you enter :4:BEFPG1 and press ()(PURG), you delete the 
first occurrence of BPG1 in port 32, 31,... , 2, 1, 0, or 
main memory. 


To get a list of backup objects in a port: 
a Enter the port number and press ()(CIBRARY) FARES. The 


PVARS command actually returns two results. Level 1 indicates the 
type of memory contained in the port: "ROM" (application card), 
"EYSRRAM" (merged memory), or a number (the number of available 


bytes in user memory for port 0, or in the port’s independent 
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memory for another port). Level 2 contains a list of backup 
identifiers and library identifiers. 


To copy backup objects from a card into another HP 48: 


1. Turn off the HP 48 and install the card—see “Installing and 
Removing Plug-In Cards” on page 28-9. 

2. Turn on the HP 48. 

3. Recall the object to the stack—see “To recall a port object to the 
stack” on page 28-3. 


You can also transfer objects between two HP 48s using their infrared 
ports—see “Transferring Data between Two HP 48s” on page 27-1. 


Backing Up All Memory 


You can back up and restore the contents of the entire HOME 
directory in a backup object. The HOME directory includes all 
variables, user key assignments, and alarms. You can also include all 
flag settings if you want. 


You can also back up memory in a computer file. See “Backing Up 
HP 48 Memory” on page 27-12. 


Caution While backing up memory, make sure the ticking 
clock is not in the display. If the clock is in the 
o display, it may corrupt the backup data. 


To back up all of user memory in a backup object: 


1. Optional: To back up flags settings too, press (|) (MODES) FLAG 
EELE., enter a variable name (with * delimiters), and press 


2. Enter a backup specifier for the backup object to create. 
3. Press (€))(MEMORY) (NXT) £ 


ARCHIVE backs up only user memory—it does not back up 
independent memory. 
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Caution Executing RESTORE overwrites the entire contents 
of user memory with the contents of the backup 
object. To save the stack, you can save it in another 
backup object. 


To restore HP 48 user memory from a backup object: 


1. Enter the backup object’s identifier (with ! delimiters) onto the 
stack. (Remember the name includes a port number.) 

2. Press ()(MEMORY) (NXT) RESTO. 

3. Optional: To restore flag settings previously saved, recall the 
contents of the variable containing the flag data and press 


()(MODES) FLAG STOF. 


Using Libraries 


A library is an object that contains named objects that can act 

as extensions to the built-in command set. The primary use of a 
library is to serve as a vehicle for a ROM- or RAM-based application. 
A ROM-based library resides in a plug-in application card and is 
installed by inserting the card into one of the card slots. (The HP 48G 
has no plug-in card slots.) A RAM-based library can reside in a 
plug-in RAM card, or it can be transferred into user memory from 

the infrared or serial I/O port. (See the library’s documentation for 
details). 


Caution Libraries originally designed for use with the older 
HP 48S and HP 48SX models may not be compatible 
with the HP 48G and HP 48GX. Loss of memory 
may occur. You should backup your user memory 
(see page 28-5) before attempting to use such 
libraries. Contact the vendor or author of the library 
for more details about compatibility. 


Libraries offer several advantages over programs: 


# Applications you write are protected from copying because the 
contents of a library can’t be viewed, edited, or recalled to the stack. 
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a Libraries offer faster access to the variables used by applications. 
a You can designate variables used in applications as “hidden” 
(unnamed) variables, which avoids cluttering the library’s menu. 


Each library is identified two ways: 


wa A library identifier, which has the form : port: number, where 
number is a unique number associated with the library. If you press 
()(IBRARY) FORTS and the menu key for the port where you 
stored the library, the library number appears in the menu. 


a A library name, which is a sequence of characters. If you press 


(p>) (UIBRARY) in the directory where you attached the library or any 
of its subdirectories, the library name appears in the menu. 


The ability to create libraries is not built into the HP 48. Normally, 
they are created on a computer and downloaded to the HP 48 via 

a cable or plug-in card. If you are interested in creating libraries, 
contact the HP Electronic Information Service described on the inside 
back cover of this manual. 


To set up a library: 


1. Install the library in a port: 

m For an application card library, turn off the HP 48 and insert the 
card into port 1 or 2. 
w For a RAM-based library, store it in port memory. 

2. Attach the library (see below). Some libraries are “auto-attaching” 
and some must be manually attached. You can attach only one 
library to each directory—ezcept you can attach any number to the 
HOME directory. (See also the documentation that comes with the 
application card or RAM-based library for any other information 
about attaching the library.) 


To use a library, it must be installed in a port and attached to a 
directory in user memory. The attachment may happen automatically 
when you install an application card—or you may have to do it 
yourself. 


To store a RAM-based library in port memory: 


1. Put the library object on the stack. (Notice its library number and 
name.) 


2. Entet the port number for storing the library. If you use port 0, the 
library is always available, even if you remove plug-in cards. If 
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you use. a port in one of the card slots, the appropriate slot must 
contain a RAM card set up as unmerged port memory. 
. Press (STO). 
4. Optional: Purge the original library object in user memory, if you 
haven’t already done so. 


Ww 


To attach an “auto-attaching” library to the HOME directory: 


m Turn the HP 48 off and on. All auto-attaching libraries stored in 
port memory will attach themselves to the HOME directory (if not 
already attached). 


To manually attach a library to a directory: 


1. Change to the desired directory: 
m For access from all directories, change to the HOME directory. 
m For limited access, change to the desired directory. The library 
will be available only in this directory and its subdirectories. 
2. Enter the library identifier for the library—it has the form 
t port: number. 


3. Press (4)(LIBRARY) ATTAC. 
4. Turn the HP 48 off and on. 


To detach a library from a directory: 


1. Change to the directory where the library is attached. 
2. Enter the library number for the library you wish to detach. 


3. Press ()(LIBRARY) DETAE to detach it from the directory. 


To purge a library from memory: 


1. Make sure that the library has been detached from every directory 
to which it had been attached. 

2. Enter the library identifier for the library in independent memory— 
it has the form ! port! number. 

3. Press (€))(PURG) to delete the library from independent memory. If 
you receive the Object Im Use error, it indicates that the library 
is still attached to some directory. 
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Installing and Removing Plug-In Card 


The two slots for installing plug-in cards are designated Card Slot 1 
and Card Slot 2. Card Slot 1 is closest to the front of the calculator— 
Card Slot 2 is closest to the back. These slots are not identical. See 
page 28-2 for details about the differences. 


Caution Nonapproved plug-in cards and accessories may 

z cause damage to the HP 48. You can distinguish 
a potentially damaging card or plug-in accessory 
from an HP-approved card by looking at the back 
side of the card where it plugs into the HP 48. An 
approved card has a metal shutter to protect the 
HP 48 from static charges. The nonapproved cards 
and accessories examined to date by HP do not have 
this shutter, but have exposed gold contacts instead. 
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To install the battery in a new RAM card: 


1. Do not use this procedure to replace the battery in a RAM card—it 
could cause loss of memory in the RAM card. To replace a battery, 
see “To change a RAM card battery” on page A-7. 

2. Slide the battery holder from the card by inserting your thumbnail 
or a small screwdriver into the groove and pulling. 

3. The grooved side of the battery holder is marked with the + 
symbol and the word UP. Insert the battery into the holder with its 
+ side up, and then slide the holder into the card. 
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4. Write the date of installation on the card using a fine-point, 
permanent marker. The date is important for determining when to 


replace the battery. 


Battery orientation symbol 


Write installation 
date here 


t t Write contents 
here 


5. Set an alarm in the calculator for 1 year from the date of 
installation to remind you to replace the battery. (Depending on 
the use, the battery should last between 1 and 3 years. When the 
battery needs replacing, a display message will appear—but only if 
the card is in the calculator. You set this alarm to remind yourself 
in case the card isn’t in the calculator when the battery gets low.) 
To set an alarm, see “Setting Alarms” on page 26-2. To replace a 
RAM-card battery, see “To change a RAM card battery” on page 


A-7. 
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To install a plug-in card: 


1. 


Store any objects currently on the stack that you want to save. 
(Installing or removing any plug-in card erases the stack.) 


. If the card you wish to install contains any libraries or 


applications designed for the older HP 48SX model, then backup 
all user memory as a precaution before installing the card (see 
page 28-5). Not all older libraries are compatible with the 

HP 48GX and may cause loss of user memory. 

Turn off the calculator. Otherwise, all of user memory could be 
erased. 


. If the card is a new RAM card, install its battery (see above). 
. For a RAM card, check or set the write-protect switch. For a new 


RAM card, set it to Read/Write. (Always turn the calculator off 

before changing the write-protect switch.) 

m Read Only. You can read the contents of the card, but you can’t 
change, erase, or store data. It protects the contents of the 
RAM card from being accidentally overwritten or erased. Never 
use this setting for a RAM card containing merged memory. 

a Read/Write. You can read, change, and erase the contents and 
store data, as you do with built-in user memory. 


Read-only setting 
/ Read/Write setting 


Back of card 
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6. Remove the port cover at the top of the calculator by pressing 
down against the grip area and then pushing in the direction 
shown. Removing the cover exposes the two plug-in ports. 


7. Select the empty slot for the card. 

8. Position the plug-in card as shown. The triangular arrow on the 
card must point down, toward the calculator. Make sure the card 
is lined up properly with a slot opening and not positioned half in 
one slot and half in the other. 
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9. Slide the card firmly into the slot until it stops. When you first 


i 


feel resistance, the card has about E inch to go to be fully seated. 
10. Replace the port cover by sliding it on until the latch engages. 
11. Press to turn on the calculator. 


When you install a new RAM card (or one 
containing ports that you’ve never used) and turn on 
the calculator, you get the message Irmalid 
Data. You may disregard the message—ports are 
automatically initialized the first time you use them. 
Or, if you prefer, press (4)(LIBRARY) (NXT) FIHIT 
to initialize all available RAM ports. The PINIT 
command will not affect any data currently stored in 
any port. 


Caution 


Never remove a RAM card that contains merged 
memory—it will probably cause a loss of data stored 
in user memory. Before you remove the RAM card, 
you must free the merged memory. See page 28-15. 


If you accidentally remove a card with merged 
memory and see the message Replace RAM, Press 
OH, you can minimize memory loss by leaving the 
calculator on, reinserting the card in the same port, 
and then pressing (ON). 


1. If you’re removing a RAM card from Card Slot 1, make sure it 
contains unmerged, free memory—see the caution below and page 


28-15. 


2. Turn off the calculator. Do not press until you’ve removed the 


card. 


3. Remove the port cover. 


4. Press against the grip and slide the card out of the port. 


5. Replace the port cover. 
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Expanding User Memory with Plug-In RAM 
Cards 


You can extend built-in HP 48GX user memory by installing a RAM 
card into Card Slot 1 and merging its memory with user memory. 
(The HP 48G model has no plug-in card slots.) 


Each RAM card contains a battery that preserves its contents while 
the calculator is turned off and after you’ve properly removed the card 
from the calculator. (The calculator batteries power the RAM card 
only while the calculator is turned on.) 


You set up a RAM card as one of two types of memory—each with its 
own benefits. You can change between the two types—but you can’t 
use one card as both types at the same time. 


a Merged user memory. The part of user memory that’s contained 
in a RAM card—the card’s memory is merged with built-in user 
memory. This lets you expand the amount of user memory for 
creating variables and directories, and for putting objects on the 
stack. 


a Free port memory. RAM memory that’s independent of user 
memory—in built-in memory (in port 0) or in a RAM card (in 
ports 1 through 32). This lets you back up individual objects or 
entire directories, much as you’d back up computer files to a disk, 
then store it in a safe place. You can also use it to transfer data to 
another HP 48 by installing it and copying the objects there. See 
“Backing Up Data” on page 28-3. 


To check the type of memory in a port: 


a Enter the port number and press ()(LIBRARY) FV ARS. The result 
in level 1 indicates the type of memory: 
i ROM in an application card. 

z Hi Merged user memory in a RAM card. 

number Free port memory in a RAM card. 
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To merge memory on the RAM card in Card Slot 1 with user 
memory: 


1. Turn off the calculator and make sure the card is not 
write-protected. 

2. Turn the calculator back on and press (4)(LIBRARY) “ERG . If 
the card previously contained any backup objects or libraries, the 
MERGE1 command automatically moves them to a special part of 
memory called port 0. See “Using Port 0” on page 28-2. 


To free a RAM card in Card Slot 1 that’s merged into user memory: 


1. Press (4) G3) to enter an empty list. 

2. Press ()(LIBRARY) FREE. If the RAM card is already free (port 
memory), you’ll get a Fort Hot Auailable error when you 
execute FREE1. If there isn’t enough memory available to free the 
RAM card, you’ll get a memory error when you execute FREE1 
(see below). 

3. Optional: Turn off the HP 48 and unplug the card—see “To remove 
a plug-in card” on page 28-14. 


To check the amount of available user memory, press (€)(MEMORY) 

HEM —the number returned is the amount of unused user memory 
in bytes. To be able to free the RAM card, you must have an unused 
amount that’s greater than or equal to the size of the RAM card— 
otherwise, the HP 48 doesn’t have enough unused memory to allocate 
to the card. 


if there’s insufficient user memory to free a RAM card: 


m Purge unneeded variables from user memory. 

m Back up data into another RAM card installed in the other card slot 
and then purge the original variables. 

m Back up data into port 0, purge the originals, and then move the 
backup objects to the RAM card as it’s being freed (see below). 
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To free a merged RAM card and move backup objects there: 


1. 


2. 


Back up the desired objects into port 0—see “To back up an 
object” on page 28-3. 

Enter a list (with £ } delimiters) containing the simple names of 
the backup objects in port 0. 


. Press ()(MEMORY) FEEE 1. The objects named in the list are 


removed from port 0 and stored in the newly freed RAM card (in 
port memory). 


. Optional: Turn off the HP 48 and unplug the card—see “To remove 


a plug-in card” on page 28-14. 


To change the write-protect switch with the card installed: 


1. 


Make sure the card contains free, unmerged port memory—see “To 
check the type of memory in a port” on page 28-15. 


. Turn off the HP 48. 
. Move the switch to the correct position: 


m For Read Only, the switch is toward the corner of the card. 
m For Read/Write, the switch is away from the corner of the card. 


28 
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ogramming the HP 48 


This chapter is an introduction to some of the programming 
capabilites of the HP 48. For a comprehensive command listing and 
in-depth programming guide see the HP 48G Series Advanced User's 
Reference (part number 00048-90136). 


Understanding Programming 


An HP 48 program is an object with # + delimiters containing a 
sequence of numbers, commands, and other objects you want to 
execute automatically to perform a task. 


For example, if you want to find the negative square root of a number 


that’s in level 1, you might press ŒA). The following program 
executes the same commands: 


“& SF HEG H 


Without changing the program, we could show it with one command 
per line—similar to other programming languages: 


T 
HEG 
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The Contents of a Program 


As mentioned above, a program contains a sequence of objects. As 
each object is processed in a program, the action that results depends 
on the type of object, as summarized below. 


Actions for Certain Objects in Programs 


Object Action 

Command Executed. 

Number Put on the stack. 
Algebraic Put on the stack. 
String Put on the stack. 
List Put on the stack. 
Program Put on the stack. 
Global name (quoted) Put on the stack. 


Global name (unquoted) m Program executed. 

a Name evaluated. 

m Directory becomes current. 

m Other object put on the stack. 
Put on the stack. 


Contents put on the stack. 


Local name (quoted) 


Local name (unquoted) 


As you can see from this table, most types of objects are simply put 
on the stack—but built-in commands and programs called by name 
are executed. The following examples show the results of executing 

programs containing different sequences of objects. 
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Examples of Program Actions 


Program Results 
"Hello" © A E oF s Z: "Helle" 
ie IAB 
‘ite | Li ite! 
i+ HLM it = 
1 2 + ig i 2 + 
Ll e+ = EVAL iz 3 


Actually, programs can contain more than just objects—they can also 
contain structures. À structure is a program segment with a defined 
organization. Two basic kinds of structures are available: 


m Local variable structure. The — command defines local variable 
names and a corresponding algebraic or program object that’s 
evaluated using those variables. 
m Branching structures. Structure words (like DO...UNTIL...END) 29 
define conditional or loop structures to control the order of 
execution within a program. 


A local variable structure has one of the following organizations inside 
a program: 


Ho name, ... name, ‘algebraic’ + 
H+ name, ... name, Ë program * + 


The — command removes n objects from the stack and stores them 
in the named local variables. The algebraic or program object in 

the structure is automatically evaluated because it’s an element of 

the structure—even though algebraic and program objects are put 

on the stack in other situations. Each time a local variable name 
appears in the algebraic or program object, the variable’s contents are 
substituted. 
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So the following program takes two numbers from the stack and 
returns a numeric result: 


Calculations in a Program 


Many calculations in programs take data from the stack—-sometimes 
put there by the user or by another program. Here are two typical 
ways to manipulate that data: 


m Stack commands. Operate directly on the objects on the stack. 

a Local variable structure. Stores the stack objects in temporary local 
variables, then uses the variable names to represent the data in the 
following algebraic or program object. 


Numeric calculations provide convenient examples of these methods. 
The following three programs use two numbers from the stack 
to calculate the hypotenuse of a right triangle using the formula 


The first program uses stack commands to manipulate the numbers 
on the stack—the calculation uses stack syntax. The second program 
uses a local variable structure to store and retrieve the numbers—the 
calculation uses stack syntax. The third program also uses a local 
variable structure—the calculation uses algebraic syntax. Note that 
the underlying formula is most apparent in the third program. 


Local variable structures with algebraic objects are favored by many 
programmers because they’re easy to write, easy to read, and simple 
to debug. 


Structured Programming 


The HP 48 encourages structured programming. Every program has 
only one entrance point—the beginning of the program. It also has 
only one exit point—the end of the program. There are no labels 
inside a program to jump to—there are no GOTO commands to exit 
from. From an external point of view, program flow is extremely 
simple—start at the beginning, stop at the end. (Of course, inside the 


29-4 Programming the HP 48 


program you can use branching structures to control the execution 
flow.) 


You can take advantage of structured programming by creating 
“building-block” programs. Each building-block program can stand 
alone—and it can act like a subroutine in a larger program. For 
example, consider the following program: 


E GETVALUE CALCULATE SHOMAHSHER = 


This program is separated into three main tasks, each with a 
subroutine. The flow is predictable. Only the input and output of 
each subroutine matter—the internal workings don’t matter at this 
level. 


Within each subroutine, its task can be simple—or it can be 
subdivided further into other subroutines that perform smaller tasks. 
This lets you have relatively simple subroutines—even if your main 
program is large. 


So, programs become extensions to the set of built-in commands, as 
mentioned earlier. You execute them by name. They take certain 
inputs, and they produce certain results. 
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Entering and Executing Programs 


A program is an object—it occupies one level on the stack, and you 
can store it in a variable. 


To enter a program: 


1. Press (4) («>»). The PEG annunciator appears, indicating 
Program-entry mode is active. 

2. Enter the commands and other objects (with appropriate 
delimiters) in the required order for the operations you want the 
program to execute. 

a Press to separate consecutive numbers. 
a Press (>) to move past closing delimiters. 

3. Optional: Press ()() (newline) to start a new line in the 
command line at any time. 

4. Press to put the program on the stack. 


Programming the HP 48 29-5 


In Program-entry mode (FRG annunciator on), command keys 
aren’t executed—they’re entered in the command line instead. Only 
nonprogrammable operations (such as (€) and (VAR)) are executed. 


Line breaks are discarded when you press (ENTER). 


To enter commands and other objects in a program: 


m Press the keyboard or menu key for the command or object. 
or 
m Type the characters using the alpha keyboard. 


To store or name a program: 


1. Enter the program on the stack. 
2. Enter the variable name (with ' delimiters) and press (STO). 


To execute a program: 


m Press and then the menu key for the program name. 


or 

a Enter the program name (with no delimiters) and press (ENTER). 
or 

m Put the program name in level 1 and press (EVAL). 
or 


a Put the program object in level 1 and press (EVAL). 
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To stop an executing program: 


m Press (CANCEL). 


Example: Enter a program that takes a radius value from the stack 
and calculates the volume of a sphere of radius r using 


V = gar 


Step 1: If you were going to calculate the volume manually after 
entering the radius on the stack, you might press these keys: 


IMMA 183 O een 
Enter the same keystrokes in a program. ((>)( starts a 
new line.) 


Be) 
IPAM W493@ 
OO enum) 


oS a ee Be 
>NUM 


PECTRLMATR] List | HYP [REAL | BASE | 


Step 2: Put the program on the stack. 


ENTER j]: WA A e 
+ $ 
ECTREMATR, LIET | HYP | REAL | EASE | 


Step 3: Store the program in variable VOL. Then put a radius of 4 
on the stack and run the VOL program. 


C @} (hold) VOL (release) 1: z268. 882575187 
| VoL LEOsRLeORS | CME [PPAR] n | 


Example: Replace the program from the previous example with one 
that’s easier to read. Enter a program that uses a local 
variable structure to calculate the volume of a sphere. 
The program is 


Zot opo ladeteqercos! MH = 


(You need to include —NUM because 7 causes a symbolic 
result. Try the program with and without the -NUM 
command.) 
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Step 1: Enter the program. 


cic 
Ooa: FO 
SHOA, 
Ar O30HO2 
Sam 


Step 2: Put the program on the stack, store it in VOL and calculate 
the volume for a radius of 4 . 


g + p '4e3srer^' 
+NUM 


2 
MECTR[MATR, List | HYP | REAL | EASE] 


j: 268. 082573186 
ae VOL Tata 


Viewing, Debugging, and Editing Programs 


To view or edit a program: 


1. View the program: 
u If the program is in level 1, press ()(EDIT). 
m If the program is stored in a variable, put the variable name in 
level 1 and press (44)(EDIT). 
2. Make any desired changes. 
3. Press to save any changes (or press to discard 


changes) and return to the stack. 


It’s easier to understand how a program works if you execute it step 
by step, observing the effect of each step. Doing this can help you 
“debug” your own programs or understand programs written by 
others. 


To single-step from the start of a program: 


1. Put any data required by the program on the stack on the 
appropriate levels. 

2. Put the program or program name in level 1 (or the command 
line). 

3. Press RUHO GEOG to start and immediately 
suspend execution. The HALT annunciator is displayed in the 
status area. 
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4. Take any action: 
m To see the next program step displayed in the status area and 
then executed, press 257 
m To display but not execute the next one or two program steps, 
press HES T 
a To continne with normal execution, press ()(CONT). 
m To abandon further execution, press ETRE. 
5. Repeat step 4 as desired. 


To single-step from the middie of a program: 


1. Insert a HALT command in the program where you want to begin 
single-stepping. 
2. Execute the program normally. The program stops when the HALT 
command is executed, and the HALT annunciator is displayed. 
3. Take any action: 
a To see the next program step displayed in the status area and 
then executed, press SST 
a To display but not execute the next one or two program steps, 
press HES T 
m To continue with normal execution, press (€)(CONT). 
m To abandon further execution, press EIRE. 
4. Repeat step 3 as desired. 


When you want the program to run normally again, remove the HALT 
command from the program. 
To single-step when the next step is a subroutine: 


w To execute the subroutine in one step, press 
m To execute the subroutine ca sa press 


subroutine, į executes the subroutine in one Shen: 
works just like $F  —except if the next program step is a 
subroutine, it single-steps to the first step in the subroutine. 


To turn off the HALT annunciator at any time: 


a Press ETE 
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Using Programming Structures 


A programming structure allows a program to make a decision about 
how it should execute depending on given conditions or the values of 
particular arguments. Careful use of these structures make it possible 
to create programs of extraordinary flexibility. 


Conditional Structures 


Conditional structures let a program make a decision based on the 
result of one or more tests. 


Here is a summary of the conditional structures available on the 
HP 48: 


IF... THEN...END 


Enter this structure into a program by pressing 
BECH (4) IF . Its syntax is: 
IF test-clause THEH true-clause EMD 0. $ 


IF... THEN...END executes the sequence of commands in the 
true-clause only if the test-clause evaluates to true. The test-clause 
can be a command sequence (for example, A & £) or an algebraic (for 
example, 'AE'). If the test-clause is an algebraic, it’s automatically 
evaluated to a number—you don’t need —NUM or EVAL. 


IF begins the test-clause, which leaves a test result on the stack. 
THEN removes the test result from the stack. If the value is nonzero, 
the true-clause is executed—otherwise, program execution resumes 
following END. 


IF... THEN...-ELSE...END 
Enter this structure into a program by pressing 
BERCH (@) IF . Its syntax is: 


IF test-clause 
THEM true-clause ELSE false-clause EMD! 


IF... THEN...ELSE...END executes either the true-clause sequence of 
commands if the test-clause is true, or the false-clause sequence of 
commands if the test-clause is false. If the test-clause is an algebraic, 
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it’s automatically evaluated to a number—you don’t need —NUM or 
EVAL. 


IF begins the test-clause, which leaves a test result on the stack. 
THEN removes the test result from the stack. If the value is nonzero, 
the true-clause is executed—otherwise, the false-clause is executed. 
After the appropriate clause is executed, execution resumes following 


END. 


CASE...END 
To enter CASE...END in a program: 


1. Press ERCH (4) CASE to enter 
CASE...THEN...END...END. 
2. For each additional test-clause, move the cursor after a test-clause 


END and press (@) CASE to enter THEN...END. 
The syntax for the CASE...END structure is: 
CASE 
test-clause, THEH true-clause, EHE 
test-clauseg THEH true-clauseg EME 


test-clause, THEM true-clause, EHD 
default-clause (optional) 


This structure lets you execute a series of test-clause commands, then 
execute the appropriate true-clause sequence of commands. The first 
test that returns a true result causes execution of the corresponding 
true-clause, ending the CASE...END structure. Optionally, you 

can include after the last test a default-clause that’s executed if 

all the tests evaluate to false. If a test-clause is an algebraic, it’s 
automatically evaluated to a number—you don’t need —NUM or 


EVAL. 


When CASE is executed, test-clause, is evaluated. If the test is true, 
true-clause; is executed, and execution skips to END. If test-clause, is 
false, execution proceeds to test-clausez. Execution within the CASE 
structure continues until a true-clause is executed, or until all the 
test-clauses evaluate to false. If a default clause is included and all the 
test-clauses evaluate to false, the default clause executes. 
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Loop Structures 


Loop structures let a program execute a sequence of commands several 
times. To specify in advance how many times to repeat the loop, use a 
definite loop. To use a test to determine whether or not to repeat the 
loop, use an indefinite loop. 


START...NEXT 


Enter this structure into a program by pressing ERCH 
Eai P. Its syntax is: 


. start finish 3 


ET loop-clause HEST .. $ 


START...NEXT executes the loop-clause sequence of commands one 
time for each number in the range start to finish. The loop-clause is 
always executed at least once. 


START takes two numbers (start and finish) from the stack and stores 
them as the starting and ending values for a loop counter. Then, the 
loop-clause is executed. NEXT increments the counter by 1 and tests 
to see if its value is less than or equal to finish. If so, the loop-clause 
is executed again-—-otherwise, execution resumes following NEXT. 


START...STEP 


Enter this structure into a program by pressing EECH 
(PP) START. Its syntax is: 

* ... start finish START loop-clause 

increment STEF ... > 
START...STEP executes the loop-clause sequence just like 
START...NEXT does—except that the program specifies the 


increment value for the counter, rather than incrementing by 1. The 
loop-clause is always executed at least once. 


START takes two numbers (start and finish) from the stack and stores 
them as the starting and ending values of the loop counter. Then 

the loop-clause is executed. STEP takes the increment value from 

the stack and increments the counter by that value. If the argument 
of STEP is an algebraic or a name, it’s automatically evaluated to a 
number. 


The increment value can be positive or negative. If it’s positive, the 
loop is executed again if the counter is less than or equal to finish. If 
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the increment value is negative, the loop is executed if the counter is 
greater than or equal to finish. Otherwise, execution resumes following 
STEP. 


FOR...NEXT 


Enter this structure into a program by pressing E 
(4) EOR. Its syntax is 


. start finish FOR counter loop-clause Hi 


FOR...NEXT executes the loop-clause program segment one time for 

each number in the range start to finish, using local variable counter 

as the loop counter. You can use this variable in the loop-clause. The 
loop-clause is always executed at least once. 


FOR takes start and finish from the stack as the beginning and ending 
values for the loop counter, then creates the local variable counter asa 
loop counter. Then the loop-clause is executed—counter can appear 
within the loop-clause. NEXT increments counter-name by one, and 
then tests whether its value is less than or equal to finish. If so, the 
loop-clause is repeated (with the new value of counter )—otherwise, 
execution resumes following NEXT. When the loop is exited, counter 
is purged. 


FOR...STEP 


Enter this structure by pressing ERCH (@) FOR. Its syntax 
is: 


. start finish FOR counter loop-clause increment STEP ... $ 


FOR...STEP executes the loop-clause sequence Just like FOR...NEXT 
does—except that the program specifies the increment value for 
counter, rather than incrementing by 1. The loop-clause is always 
executed at least once. 


FOR takes start and finish from the stack as the beginning and ending 
values for the loop counter, then creates the local variable counter as a 
loop counter. Next, the loop-clause is executed—counter can appear 
within the loop-clause. STEP takes the increment value from the 
stack and increments counter by that value. If the argument of STEP 
is an algebraic or a name, it’s automatically evaluated to a number. 
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The increment value can be positive or negative. If the increment is 

positive, the loop is executed again if counter is less than or equal to 
finish. If the increment is negative, the loop is executed if counter 

is greater than or equal to finish. Otherwise, counter is purged and 

execution resumes following STEP. 


DO...UNTIL...END 


Enter this structure into a program by pressing E 
(4) G4. Its syntax is: 


. EO loop-clause UHTIL test-clause END 


DO...UNTIL...END executes the loop-clause sequence repeatedly until 
test-clause returns a true (nonzero) result. Because the test-clause is 
executed after the loop-clause, the loop-clause is always executed at 
least once. 


DO starts execution of the loop-clause. UNTIL marks the end of 

the loop-clause. The test-clause leaves a test result on the stack. 

END removes the test result from the stack. If its value is zero, 

the loop-clause is executed again—otherwise, execution resumes 
following END. If the argument of END is an algebraic or a name, it’s 
automatically evaluated to a number. 


WHILE...REPEAT...END 


Enter this structure into a program by pressing BEREH 
(Q)HHILE. Its syntax is: 


T 


.. WHILE test-clause REPEAT loop-clause EHD ... > 


WHILE...REPEAT...END repeatedly evaluates test-clause and 
executes the loop-clause sequence if the test is true. Because the 
test-clause is executed before the loop-clause, the loop-clause is not 
executed if the test is initially false. 


WHILE starts execution of the test-clause, which returns a test result 
to the stack. REPEAT takes the value from the stack. If the value 

is nonzero, execution continues with the loop-clause—otherwise, 
execution resumes following END. If the argument of REPEAT is an 
algebraic or a name, it’s automatically evaluated to a number. 
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Error Trapping Structures 


Many conditions are automatically recognized by the HP 48 as error 
conditions—and they’re automatically treated as errors in programs. 
A command with an improper argument or an improper number of 

arguments causes an error in a program. An out-of-range result can 
cause an error. An invalid calculator condition can cause an error. 


Error trapping structures allow programs to intercept (or trap) error 
conditions that otherwise would cause the program to abort. 


IFERR...THEN...END 


Enter this structure into a program by pressing k 
(4) [FERE. Its syntax is: 


f trap-clause THEH error-clause EHD ... $ 


The commands in the error-clause are executed only if an error is 
generated during execution of the trap-clause. If an error occurs in the 
trap-clause, the error is ignored, the remainder of the trap-clause is 
skipped, and program execution jumps to the error-clause. If no errors 
occur in the trap-clause, the error-clause is skipped and execution 
resumes after the END command. 


IFERR...THEN...ELSE...END 29 


Enter this structure into a program by pressing ERROR 
(@) LFERR. Its syntax is: 


a pai 


IFERR trap-clause 
THEM error-clause ELSE normal-clause EHD 


The commands in the error-clause are executed only if an error is 
generated during execution of the trap-clause. If an error occurs in the 
trap-clause, the error is ignored, the remainder of the trap-clause is 
skipped, and program execution jumps to the error-clause. If no errors 
occur in the trap-clause, execution jumps to the normal-clause at the 
completion of the trap-clause. 
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Using Local Variables 
There are disadvantages to using global variables in programs: 


a After program execution, global variables that you no longer need 
to use must be purged if you want to clear the VAR menu and free 
user memory. 

w You must explicitly store data in global variables prior to program 
execution, or have the program execute STO. 


Local variables address the disadvantages of global variables in 
programs. Local variables are temporary variables created by a 
program. They exist only while the program is being executed and 
cannot be used outside the program. They never appear in the VAR 
menu. In addition, local variables are accessed faster than global 
variables. (By convention, this manual uses lowercase names for local 
variables.) 


Creating Local Variables 


In a program, a local variable structure creates local variables. 


To enter a local variable structure in a program: 
1. Enter the — command (press (@)@))- 


2. Enter one or more variable names. 

3. Enter a defining procedure (an algebraic or program object) that 
uses the names. 
& + name, nameg ... namey ‘algebraic’ + 
or 


Ho name, nameg ... NAME = program OR 


When the — command is executed in a program, n values are taken 
from the stack and assigned to variables namei, nameg, ... Namen. 
For example, if the stack looks like this: 
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r 
x= 
o 
= 
m 
ty! 


PU 


p 
p 
E 
E 


then 

+ a creates local variable a = 20. 

* a & creates local variables a = 6 and b = 20. 

> ab g creates local variables a = 10, b = 6, and c = 20. 
The defining procedure then uses the local variables to do calculations. 
Local variable structures have these advantages: 


m The — command stores the values from the stack in the 
corresponding variables—you don’t need to explicitly execute STO. 


æ Local variables automatically disappear when the defining procedure 
for which they are created has completed execution. Consequently, 
local variables don’t appear in the VAR menu, and they occupy user 
memory only during program execution. 


m Different local variable structures can use the same variable names 
without conflict. 


Evaluating Local Names 


Local names are evaluated differently from global names. When a 
global name is evaluated, the object stored in the corresponding 
variable is itself evaluated. (You’ve seen how programs stored in 
global variables are automatically evaluated when the name is 
evaluated.) 


When a local name is evaluated, the object stored in the 
corresponding variable is returned to the stack but is not evaluated. 
When a local variable contains a number, the effect is identical to 
evaluation of a global name, since putting a number on the stack is 
equivalent to evaluating it. However, if a local variable contains a 
program, algebraic expression, or global variable name—and if you 
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want it evaluated—the program should execute EVAL after the object 
is put on the stack. 


Using Local Variables within Subroutines 


Because a program is itself an object, it can be used in another 
program as a subroutine. When program B is used by program” 
A, program A calls program B, and program B is a subroutine in 
program A. 


Normally, a local variable exists only inside its defining procedure (and 
not within any subroutines called by the defining procedure). Thus, 
normal local variables can only be used within a subroutine if the 
subroutine is embedded, or nested within the local variable’s defining 
procedure. 


However, the HP 48 offers a way to include local variables in 
subroutines that are not nested within the local variable’s defining 
procedure. 


To use a local variable in a subroutine called by the variable’s 
defining procedure: 


a When defining the local variable, name it using + (QLCO) as the 
first character. This creates a compiled local variable. 

a When calling the local variable within a subroutine, specify its name 
using + as the first character. 


A compiled local variable is available to any subroutine called by the 
defining procedure for the local variable. However, compiled local 
variables are still local variables and are purged when the defining 
procedure is completed. 


Local Variables and User-Defined Functions 


The defining procedure for a local variable structure can be either an 
algebraic or program object. 


A user-defined function is actually a program that consists solely of 
a local variable structure whose defining procedure is a an algebraic 
expression. The syntax is: 


x + name, nameg... NAMEn t expression! 
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It takes an unlimited number of arguments (can use an unlimited 
number of local variables), but returns one result to the stack. 


If a program begins with a local variable structure and has a program 
as the defining procedure that returns exactly one result, the complete 
program acts like a user-defined function in two ways: 


m It takes numeric or symbolic arguments. 
m It takes its arguments either from the stack or in algebraic syntax. 


However, although such a program can contain commands not allowed 
in algebraic expressions, it does not have a derivative. 


Exploring the Programs in the EXAMPLES 
Directory 


To use and explore the EXAMPLES directory: 


1. Type TESCH into the command line and press (ENTER). This loads 
the EXAMPLES directory from built-in memory into your HOME 
directory where you can access it. 


2. Press EXAM to open the EXAMPLES directory. 29 


EXAMPLES 


r 


PRGS PLOTS EQNS %TILE PURGEX 


MEDIAN FIBON APLY >RPN ONE TWO THREE FOUR RATFUNC 


XSIN ELLIP LISSA ROSE PTRN DEQ SPFLD PSCN GRID PSUR WIRE SLICE 


All of the objects contained in EXAMPLES (apart from the 
subdirectories PRGS, PLOTS, and EQNS) are either programs or 
algebraic objects. The algebraics in the EQNS subdirectory are used 
in examples in the HP {8G Series Quick Start Guide. The short 
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programs contained in PLOTS each plot an example of a different plot 
type. The remaining objects are example programs that accomplish a 
variety of different tasks. 


MEDIAN Returns a vector containing the median values for 
each column in the current statistics matrix. 

FIBON Using the contents of variable n, returns the n-1 
Fibonacci number. 

APLY Applies a program to each element of an array. The 


program applied must take exactly one input and 
return exactly one output. If output is symbolic the 
result is returned as a “symbolic array” (that is, a 
list of “row” lists instead of an array of row vectors). 
—RPN Converts an algebraic object into a list of equivalent 
RPN commands. Evaluating the resulting list 
returns the original algebraic. Illustrates the 
equivalency between algebraic and RPN procedures. 
%TILE Takes a list of data on level 2 and a percentile 
number on level 1 and returns the value of the 
percentile for the list. For example, typing 
£datalist } 54 and pressing #T1 CE returns the 
median (50th percentile) of the list. 


You may wish to work through these programs using single-stepping 
(see page 29-8). 


Using HP 48S/SX programs with the 
HP 48G/GX 


There are many programs distributed (both commercially and 
otherwise) today that were originally written for the HP 48S and 
HP 48SX, the predecessors of the HP 48G Series. 


a ee ER a ae 
Caution Before running a library developed for the HP 485 
Series calculators on your HP 48G Series calculator, 
back up the contents of your memory to an external 
source (computer or plug-in card). Incompatibilities 
between the library and the HP 48G Series calculator 
may cause memory loss. 


29-20 Programming the HP 48 


There are no guarantees that such programs will run without errors on 
the HP 48G Series calculators. However, most older programs that use 
only User-RPL commands—the set of commands that are recognized 
when you type in their names on the keyboard—will work on the 
newer HP 48G Series. 


There are some differences between the older HP 485 Series and the 
newer HP 48G Series that may (or may not) affect older programs: 


w HP 485 Series programs using the SYSEVAL command may cause 
memory loss when run on a HP 48G Series calculator due to 
changes in the internal memory mapping. 

m HP 488 Series programs that use variable names that are identical 
to commands newly introduced on the HP 48G Series calculators 
will give unpredictable results due to the name conflict. Changing 
the names used in the older program will prevent this problem, 

a HP 48S Series programs that use the MENU command to display 
a built-in menu may give unexpected results because the HP 48G 
Series calculators uses a different menu structure (see Appendix C). 

m HP 48S Series programs that use flags -14, -28, -29, or -54 will 
conflict with the built-in meanings for these flags in the HP 48G 
Series calculators. 


Some commercially-distributed libraries developed for the HP 48S 
Series may not work on the HP 48G Series and may, in fact, cause 
memory loss. In addition, some libraries on plug-in cards may only 
work when the card is stored in Card Slot 1; others may only work 
when the card is stored in Card Slot 2. Be sure to backup user 
memory before experimenting with an untested library. 


Where to Find More Information 
m The HP 48G Series Advanced User’s Reference (part number 


00048-90136) contains programming information, including syntax 
information for all HP 48G Series commands, in a reference format. 


m The HP Calculator Bulletin Board System (see inside back cover) 
provides a forum for exchange of information about the availability 
and compatibility of software developed for either Series S or Series 
G calculators. It is also a good source of programming tips and 
interesting programs. 
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Customizing Menus 


A custom menu is a menu that you create. It can contain menu labels 
for operations, commands, and other objects that you create or group 
together for your own convenience. 


A custom menu is defined by the contents of a reserved variable 
named CST. So, the way to create a custom menu involves creating a 
variable CST that contains the objects you want in your menu. 


To create and display a custom (CST) menu: 


1. Enter a list containing the objects you want in the menu. (The 
different object types serve different purposes.) 


2. Press ()(MODES) MENU MENU. 
To display the current CST menu: 


m Press (CST). 


Objects in the CST menu usually have the same functionality they do 
in built-in menus: 


m Names. Names behave like VAR menu keys. Thus, if ABC is a 
variable name, © ġ evaluates ABC, (>) AEC. recalls its 
contents, and HEC stores new contents in ABC. Also, the 
menu label for the name of a directory has a bar over the left corner 
of the label—pressing the menu key switches to that directory. 


w Units. Unit objects act like UNITS Catalog entries. For example, 
they have their left-shifted conversion capability. 


m Strings. String objects echo the contents of the string, like a typing 
aid. 
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a Commands. Almost all command names behave like normal 
command keys. 


You can include backup objects in the list defining a custom menu by 
tagging the name of the backup object with its port location. For 


example, if #2? TOM were included in the custom menu list, a menu 
label TCM would represent the backup object TOM in port 2: 


If you want to create typing aids for certain commands that affect 
program flow (such as HALT, PROMPT, IF... THEN...END, and other 
program control structures), include them as string objects, not as 
command names. 


Example: Create a custom menu containing the built-in command 
— TAG, the unit object Lr”, a string to serve as a 
typing aid for YOLUME, and the variable name CST. 


Step 1: Enter the list of objects. 


1MO OW) 
MCD VOLUME (@) 


e 
(a}(hold) CST (release) 
ENTER 


Step 2: Create and display the CST menu. 
(4)(MODES) MENU MENU Tata] M3 | 


{ TAG 1-m^3 
"WOLUME" CST 3 


Step 3: Convert 1075 cm? to m. 


173 BOOS): Om 
3 


1: „001075-m^3 
raal ea eoul cst} 1 __ 


Step 4: Enter the string SVOLUINE®. 


: „001075 m^3 
: "VOLUME" 
pest e 
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Step 5: Create a tagged object from the contents of levels 2 and 1. 


1: VOLUME: .@81873_m"3 
etajera emu cet] O 


STAG 


Step 6: Display the current contents of CST. 
LAT 2: VOLUME: Po ee -n°3 


: è TRG l 
"VOLUME" CST 4 
etaa ra oou eer 


You can create a CST in each directory in memory, just as you can for 
other variables. This lets you have a different custom menu in each 
directory. 


Also, instead of storing the list of objects itself in CST, you can 
optionally store the name of another variable that contains the list. 
This gives you the ability to have in one directory several variables 
that contain different custom-menu lists. That way, you can easily 
switch the CST menu from one custom menu to another by simply 
storing a new name in CST. 


Enhancing Custom Menus 

You can enhance the CST menu by creating special menu labels and 
by specifying different actions for unshifted and shifted keys. 

To create a special menu label for an object: 


m Inside the CST list, replace the object by an embedded list of the 
form £ "label" object }. 


The default label for an object in the CST menu is the underlying 
name, command, unit, or typing aid—as many characters as fit in the 
space available. 


gg uyi n 


at 


Example: Storin 

z tin CST gives dhe same > CST menu 
operations as the p previous example, put the labels are 
STAG, OMS, ONO, and US 
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To specify functionality for shifted keys: 


a Inside the CST list, replace the object by an embedded list of 
objects: € objectunshittea ObjeCticti-shitt ObjeCtright-shitt +. (You can 
omit the last one or two objects if you want.) 


You must specify the unshifted action in order to have the shifted 
actions. In addition, you can combine the special-label enhancement 
and the shifted-functionality enhancement—see the following example. 


Example: Suppose you want the CST menu key iL to provide 
the following three actions: 


m (QL evaluates a program that stores the value in 
level 1 in a variable named VBOX. 

m (#) VOL evaluates a program that computes the 
product of levels 1, 2, and 3. 

mw (p>) VEL types VOLUME. 


The following CST list provides the desired custom menu. The menu 
contains only one label: | OL 


HRDLO T oe MES! STO b €a $ # = "VOLUME # 


To create a temporary menu: 


1. Enter the menu list as with CST. 
2. Press ()(MODES) MEHL THEH. This creates and displays a 


temporary menu without overwriting the contents of the variable 


CST. 


Customizing the Keyboard 


The HP 48 lets you assign alternate functionality to any key on 
the keyboard (including alpha and shifted keys), enabling you to 
customize the keyboard for your particular needs. Your customized 
keyboard is called the user keyboard, and it’s active whenever the 
calculator is in User mode. 
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User Modes 


To activate User mode: 


a If you want to execute only one operation (1482F), press ()(USER). 
(It turns off after the operation.) 

a If you want to execute several operations (USER), press (C) (USER) 
(4) (USER). (Press (4)(USER) a third time to turn off User mode.) 


The ()(USER) key is a three-way switch, much like the (a) key. 
Pressing the key once activates the mode only for the next operation, 
while pressing it twice consecutively locks the mode on, requiring a 
third press to turn the mode off again. If you prefer, set Flag —61 to 
enable a single press of (€;)(USER) to lock User mode on. 


Assigning and Unassigning User Keys 


You can assign commands or other objects to any user keys (including 
shifted keys). The behaviors for different types of objects are the same 
as for custom menus—see “Customizing Menus” on page 30-1. 


To assign an object to a user key: 


1. Enter the object to be assigned to the key. 
2. Enter the three-digit location number that specifies the key. (See 
the diagram below.) 


3. Press («) (MODES) REVS CASH 
Keyboard column# 
v 


XX.X <> 0or 1 = unshifted 
2 = lefi-shifted 


T 3 = right-shifted 
! 4 = alpha 
Keyboard row# 5 = alpha left-shifted 


6 = alpha right-shifted 


To assign a built-in command to a user key: 
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1. Enter a list containing two parameters—the command to be 
assigned to the key followed by the three-digit key location number 
(see above). 


2. Press ()(MODES) KEYS STOR. 
To assign several user keys: 


1. Enter a list containing two key-assignment parameters for 
each key—the object to be assigned to the key followed by the 
three-digit key location number (see above). 


2. Press (MODES) 


This is an example of a key-assignment list for STOKEYS: 


SOP rr 


You can use ‘SKE! as an assignment object. It means the 
“standard” (unassigned) key definition. 


When you press a user key, its assigned object is executed—or, if the 
key is unassigned, the standard operation is performed. (You can also 
disable keys, as described in the next topic.) 


After you’ve assigned a user key, the assignment remains in effect until 
you reassign the key using ASN or STOKEYS, or until you unassign 
the key. An unassigned user key reverts to its standard definition—the 
same as for the standard keyboard. 


To unassign previously-assigned user keys: 


m To unassign one user key, enter the three-digit key number, then 
press (4)(MODES) KEYS ELE. An unassigned user key reverts 
to its standard definition—the same as for the standard keyboard. 

m To unassign several user keys, enter a list containing the three-digit 
key numbers, then press (9) (MODES) KEYS £ 

m To unassign all user keys, press 0 EEDE | E PELE. All 
user keys are unassigned and all disabled keys are enabled (see next 
topic). 
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Disabling User Keys 


You can disable user keys that are unassigned—so they do nothing. 
This lets you control the user keys that are active, including assigned 
keys and standard (unassigned) keys. 


If you assign a disabled user key, it becomes enabled. 


To disable all unassigned user tied 
m Enter 'S' and press ()(MODES) KEYS PELE. 
To reenable unassigned, disabled user keys: 


m To enable one unassigned key, enter ' =! , enter the three-digit 


key number, then press (€)(MODES) ! ASH 


m To enable several unassigned keys, enter a list containing 'SKE‘' 


and the three-digit key number for each key, then press (4)(MODES) 


EYS. STOE . (Include one 'SEE‘'' for each key.) 
a To eiable and unassign all user keys, press 0 (|) (MODES) KEYS 
BELE 


To reenable and assign disabled user keys: 


w To enable and assign one user key, enter the object to be assigned to 
the key, enter the three-digit key number, then press (4) (MODES) 
kerm. ASH 

m To enable all user keys and assign several keys, enter a list with = as 
the first object, followed by the assigned object and three-digit key 
number for each key assignment, then press ()(MODES) KEYS 


SPOR. 


Recalling and Editing User Key Assignments 


To recall the current user key assignmenis: 
m Press (€4)(MODES) KEYS RELE (the RCLKEYS command). 


The RCLKEYS command returns to level 1 a list of all the current 
user key assignments—pairs of assignment objects and three-digit key 
numbers. If the first item in the list is the letter =, then unassigned 
user keys are currently enabled—otherwise, unassigned keys are 
currently disabled. 
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To edit the user key assignments: 


1. Press ()(MODES) KEYS FCLE (the RCLKEYS command). 

2. Press (4)(EDIT) and edit the key-assignment list. 

3. Press ()(MODES) KEYS DELE STOE (the STOKEYS 
command) to delete the old assignments and activate the edited 
assignments. 


Note If you get stuck in User mode—probably with a 
“locked” keyboard—because you’ve reassigned or 

l disabled the keys for canceling User mode, hold down 

the key and press the C key, then release the C 

key first. 


Deleted user key assignments still take up from 
2.5 to 15 bytes of memory each. You can free this 
memory by packing your user key assignments—press 


(4)(MODES) KEYS RELE 0 DELE STOR. 
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Answers to Common Questions 


You can obtain answers to questions about using your calculator from 
our Calculator Support department. Our experience has shown that 
many customers have similar questions about our products, so we’ve 
provided this section to answer many of these questions. If you don’t 
find the answer to your question here, contact us at the address or 
phone number on the inside back cover. 


Q: Sometimes my HP 48 will flash when I turn it on. Is this normal? 
A: This is normal for the HP 48. 


Q: I’m not sure whether the calculator is malfunctioning or if I’m 
doing something incorrectly. How can I verify that the calculator is 
operating properly? 

A: See “Testing Calculator Operation” on page A-9. 


Q: The () annunciator stays on even when the calculator is turned 
off. Is anything wrong? 

A: This indicates a low-battery condition in the calculator or a RAM 
card, or an alarm that is past due. To determine what is causing 
the () annunciator to stay on, turn the calculator off and then on. 
A message in the display will identify the problem. See “When to 
Replace Batteries” on page A-4 or “Responding to Alarms” on page 
26-4. 


Q: How can I determine how much memory is left in the calculator? 
A: Press ()(MEMORY) MEM . The number of bytes of available 
memory will appear at the lower right corner of the display. 

For example, an empty memory for the HP 48GX should show 
approximately 127888 bytes of internal RAM (with no RAM cards 
installed). 
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Q: What does an E in a number mean (for example, 2.31E~-12)? 
A: Exponent of 10 (for example, 2.51 x 10719). See “Keying In 
Numbers” on page 2-1 and “Setting the Display Mode” on page 4-2. 
Q: Why do trig functions give me unexpected results? 


A: The angle mode may be wrong for your problem. Check the angle 
mode annunciator: FAG means radians, GEAL means grads, and none 


means degrees. Press (€)(RAD) or use the (>)(MODES) screen to 


change the angle mode. 


instead of a number? 


A: The calculator is in Symbolic Result mode; 'SIH¢w2' is the 


symbolic answer. Press (¢,)(#NUM) to convert 'SIHiw2' to its 


numeric equivalent of .0548 ... up to 11 decimal places (sin 3.14°). 
You can also press ()(MODES) MISC SM to change to Numeric 


Results mode and prevent symbolic evaluation. 


Qi When I evaluate 'SIMéws' I don’t get zero. Why not? 

A: The HP 48, like all calculators, can only compute using a finite 
number of decimal places. Because m contains an infinite number of 
decimal places, any results involving m must necessarily be rounded. 
Sometimes, as in this case, the rounded number differs from the 
theoretical answer by 10+? (a millionth of a millionth) or so. 


Q: When I differentiate or integrate I get an Unde? ined Hame error 
message. What is wrong? 


A: Symbolic solution mode is not set and the calculator is attempting 
(unsucessfully) to find a numerical answer using only symbolic 


variables. Press ()(MODES) HISE SYNE , or make sure that the 
RESULTS: field in the Integrate or Differentiate input forms shows 


ne 


alig, and try again. 

Q: When I compute (-1)3 I get a complex number instead of 1. What 
is wrong? 

A: The HP 48 is designed to return the complex principal solution for 


any fractional exponent. To get the real number root, use the ~/Y 
operator (the key or XROOT command) instead. 


Q: What does “object” mean? 


A: “Object” is the general term for all elements of data the HP 48 
works with. Numbers, expressions, arrays, programs, and so on, are all 
types of objects. 
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Q: What do three dots (n) mean at either end of a display line? 
A: The three dots (called an ellipsis) indicate that the displayed 


object is too long to display on one line. To view undisplayed portions 
of the object, use the (€) or (>) cursor keys. 


Q: How do I turn off the HALT annunciator? 
A: Press RUM EITEL. 


Q: The calculator beeps and displays Bad Argument Tupe., What’s 
wrong? 

A: The objects on the stack aren’t the correct type for the command 
you are attempting. For example, executing +#UHIT (in the PRG 
TYPE menu) with a number in stack levels 1 and 2 causes this error. 


Q: The calculator beeps and displays Too Few Arguments. What’s 
wrong? 

A: There are fewer arguments on the stack than required by the 
command you are attempting. For example, executing with only 
one argument or number on the stack causes this error. 


Q: The calculator beeps and displays a message different from the two 
listed above. How do I find out what’s wrong? 


A: Refer to appendix B, “Messages.” 


Q: I can’t find some variables that I used earlier. Where did they go? 
A: You may have been using the variables in a different directory. If 
you can’t remember which directory you were using, you’ll need to 
check all the directories in your calculator. 


Q: Sometimes my HP 48 seems to pause momentarily during a 
calculation. Is anything wrong? 

A: Nothing is wrong. The calculator does some system cleanup from 
time to time to eliminate temporary objects created from normal 
operation. This cleanup process frees memory for current operations. 
This happens less often if you make more memory available. 


Q: The Equation Library Solver gives me SI units even when I specify 


(or vice-versa). 

A: The Solver uses and creates global variables. If the variables in 
question were created before, then they still exist (until you purge 
them). Their unit definitions also still exist. To override the old unit 
system, you must either purge the variables before solving, or you 
must enter the specific units you want (such as _# +4). 
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Environmental Limits 


To maintain product reliability, avoid getting the calculator and 
plug-in cards wet, and observe the following temperature and humidity 
limits: 


Calculator: 


m Operating temperature: 0° to 45°C (32° to 118°F). 

m Storage temperature: —20° to 65°C (—4° to 149°F). 

a Operating and storage humidity: 90% relative humidity at 40°C 
(104°F) maximum. 


Plug-In Cards: 


m Operating temperature: 0° to 45°C (32° to 113°F). 

m Storage temperature: —20° to 60°C (—4° to 140°F). 

m Storage temperature for RAM card data retention: 0° to 60°C (32° 
to 140°F). 

Operating and storage humidity: 90% relative humidity at 40°C 
(104°F) maximum. 


When to Replace Batteries 


When a low-battery condition exists, the (+) annunciator remains 
on, even when the calculator is turned off. When the calculator is 
turned on during a low-battery condition, Harmina: LowEati 3 is 
displayed for approximately 3 seconds: 


Replace the RAM card battery or the calculator 
batteries as soon as possible after the (+) 
low-battery annunciator and warning message 
appear. If you continue to use the calculator while 
the (e) annunciator is on, the display will eventually 
dim and you may lose calculator and RAM card 
data. 
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Under typical use, a RAM card’s battery should last between 1 and 

3 years. Be sure to mark the card with the battery-installation date, 
and, in case the RAM card is not in the calculator when the battery 
needs replacement, set an alarm for 1 year from that date to remind 
you to install a fresh battery. RAM cards do not come with a battery 
installed. 


Changing Batteries 
The HP 48 uses the following kinds of batteries: 


m Calculator Batteries. Any brand of size AAA batteries. Be sure 
that all three batteries are of the same brand and type. (The use of 
rechargeable batteries is not recommended because of their lower 
capacity and short low-battery warning time.) 


m Plug-In RAM Card Batteries. 3-volt 2016 coin cell. (Not used in 
the HP 48G.) 


To replace calculator batteries, use the steps below. To replace RAM 
card batteries, see “To change a RAM card battery” on page A-7. 


Whenever you remove batteries from the calculator, 
be sure the calculator is off, and do not press the 
key until the new batteries are installed. If you press 
when batteries are not in the calculator, you 
may lose all calculator memory. 


To change calculator batteries: 


1. Turn the calculator off. You may lose memory in the calculator and 
plug-in RAM cards if the calculator batteries are removed when the 
calculator is on. 


2. Have three, fresh size AAA batteries (of the same brand and type) 
at hand. Wipe off both ends of each battery with a clean, dry 
cloth. 
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3. Remove the calculator battery-compartment door by pressing down 
and sliding it off away from the calculator. Be careful not to press 
the calculator’s key. See the following illustration. 


4. Turn the calculator over and shake the batteries out. After the 
batteries are out, you should replace them with fresh batteries 
within 2 minutes to protect against memory loss. 


Warning Do not mutilate, puncture, or dispose of batteries 
in fire. The batteries can burst or explode, 
7) releasing hazardous chemicals. Discard used 
batteries according to the manufacturer’s 


instructions. 
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or 


. Position the batteries according to the outlines in the bottom of 
the battery compartment. Avoid touching the battery terminals. 
Batteries are easier to install if the negative (plain) ends are 
inserted first, and if the center battery is installed last. See the 
following illustration. 


6. Replace the battery-compartment door by sliding the tabs on the 
door into the slots in the calculator case. 


7. Press to turn the calculator on. 


To change a RAM card battery: 


1. Turn the calculator over and remove the plastic cover over the 
plug-in card ports (on the display-end of the calculator). 


2. With the RAM card in port 1 or 2, turn on the calculator. 
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Caution Make sure you turn on the calculator before you 
change a RAM card battery. RAM cards run off the 
calculator batteries only while the calculator is on. 
RAM memory may be lost if you remove a RAM 
card battery while the calculator is off, or while the 


3. Place your index finger in the recess near the exposed end of the 
RAM card—this prevents removal of the card from the calculator 
when you remove the card’s battery holder. Now insert the 
thumbnail of your free hand into the nail grip in the black plastic 
at the left side of the end of the card and pull the battery holder 
out of the card. 


Nail grip ————_ 


4. Remove the old battery from the plastic battery holder. 


Warning Do not mutilate, puncture, or dispose of batteries 

in fire. The batteries can burst or explode, 
releasing hazardous chemicals. Discard used 
batteries according to the manufacturer’s 
instructions. 
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Install a fresh, 3-volt 2016 coin cell in the plastic battery holder, 
and reinsert the holder (with battery) into the card. Be sure to 
install the battery with the side marked “+” toward the front of the 
card. 


Mark the card with the battery-installation date, and set an alarm 
for 1 year from that date to remind you to change it. (If you 
unplug the card, the HP 48 can’t check the card’s battery level.) 


Replace the plug-in port cover. 


Testing Calculator Operation 


Use the following guidelines to determine whether the calculator is 
functioning properly. Test the calculator after every step to see if 
operation has been restored. If your calculator requires service, see “If 
the Calculator Requires Service” on page A-16. 


if the calculator won’t turn on or doesn’t respond when you press 
the keys: 


1. 


on 


Make sure that three fresh batteries are correctly installed in the 
calculator. 


. Press and release (ON). 


. If the calculator comes on, but the display is blank, press and hold 


(ON), press and release several times until characters become 
visible, then release (ON). If no characters appear in the display, the 
calculator requires service. 


If a halted program won’t respond when you press (CANCEL), try 
pressing again. 


If the keyboard is “locked,” perform a system halt: 


Press and hold (ON). 

Press and release the “C” key (the key with C next to it). 
Release (ON). The empty stack display should appear. 

If the problem still exists, perform a manual system halt (see 
page 5-17). 


Bei Qe 
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6. If the problem still exists, perform a memory reset. You may lose 
data during a memory reset, so do this only if you must: 


a. Press and hold (ON). 

b. Press and hold the “A” and “F” keys (the keys with A and F 
next to them). 

c. Release all three keys. 


The calculator will beep and display the message Try To Remcuer 
Memory? at the top of the display. Press YES to recover as 
much memory as possible. 


If these steps fail to restore operation, the calculator requires service. 


if the calculator responds to keystrokes, but you suspect it’s 
malfunctioning: 


1. Run the self-test described in the next section. 

m If the calculator fails the self-test, it requires service. 

m If the calculator passes the self-test, you may have made a 
mistake operating the calculator. Reread appropriate portions of 
the manual and check “Answers to Common Questions” on page 
A-1. 

2. Contact the Calculator Support department. The address and 
phone number are listed on the inside back cover. 


Self-Test 


If the display turns on, but the calculator does not seem to be 
operating properly, run the diagnostic self-test. 


To run the self-test: 


1. Turn on the calculator. 
2. Press and hold (ON). 
3. Press and release the “E” key (the key with E next to it). 


4. Release (ON). 


The diagnostic self-test tests the internal ROM and RAM, 
and generates various patterns in the display. The test repeats 
continuously until you perform a system halt. 
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To halt the self-test (system halt): 


1. Press and hold (ON). 
2. Press and release the “C” key (the key with C next to it). 
3. Release (ON). The empty stack display should appear. 


If the self-test indicates an internal ROM or RAM failure (if TRI 
and TRAM GE are not displayed), the calculator requires service. 


The diagnostic self-test should be successfully completed before 
running any of the tests described in the following sections. 


Keyboard Test f 


This test checks all of the calculator’s keys for proper operation. 


To run the interactive keyboard test: 


1. Turn on the calculator. 

2. Press and hold (ON). 

3. Press and release the “D” key (the key with D next to it). 

4. Release (ON). 

5. Press and release the “E” key (the key with E next to it). KEDI 
will appear in the upper left corner of the display. 

6. Starting at the upper left corner and moving left to right, press 


each of the 49 keys on the keyboard. 


If you press the keys in the proper order and they’re functioning 
properly, the calculator emits a high-pitch beep at each press of a 
key. When you press the 49th key, @), the displayed message should 
change to KEDI Ok 


If you press a key out of sequence, a five-digit hexadecimal number 
will appear next to KEE1. Rerun the test by repeating steps 2 through 
6 above. 


If a key isn’t functioning properly, the next keystroke displays the hex 
location of the expected and the received location. If you pressed the 
keys in order and got this message, the calculator requires service. 

Be sure to include a copy of the error message when you ship the 
calculator for service. 
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To exit the keyboard test (system halt): 


1. Press and hold (ON). 
2. Press and release the “C” key (the key with C next to it). 


3. Release (ON). The empty stack display should appear. 


Port RAM Test 


The port RAM test nondestructively tests the ports (for those 
calculators that have them) and the installed plug-in RAM cards. 
(Plug-in RAM-card memory is preserved.) 


To run the port RAM test: 


1. Check that a plug-in RAM card is properly installed in port 1 or 


port 2. 
2. Verify that the switch on each card is set to the “Read/Write” 
position. 


Read-only setting 
Read/Write setting 


Back of card 


3. Turn on the calculator. 


4. Press and hold (ON). 
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5. Press and release the “D” key (the key with D next to it). 

6. Release . A vertical line will appear at both sides and at the 
center of TA display. 

7. Press and release (A). 


= will appear at the top left corner of the display and 


the size of ine corresponding plug-in RAM card (328 or 128) will 
appear at the ss right corner of the display. Gi will appear to the 
right of RAHL or RAME when the port RAM test has been successfully 
completed. 


A failure message (for example, EAI ) will be displayed for 
each port that does not contain a plug-in RAM card or if a card’s 

read/write switch is in the “write-protect” position. This message 

should be ignored. 


If ük doesn’t appear for a RAM card set to read/write, the card 
should be moved to the other port and the test rerun. If OF still 
doesn’t appear, the RAM card should be replaced with a new one. 


To return to normal caiculator operation (system halt): 


1. Press and hold (ON). 
2. Press and release the “C” key (the key with C next to it). 
3. Release (ON). The empty stack display should appear. 


IR Loop-Back Test 


This test checks the operation of the send and receive infrared sensors 
and their associated circuits. 


To run the IR loop-back test: 


1. Turn on the calculator. 

2. Press and hold (ON). 

3. Press and release the “D” key (the key with D next to it). 

4. Release (ON). A vertical line will appear at both sides and at the 
center of the display. 

Be sure that the plastic plug-in card cover is in place and that it 
covers the clear lamp bulbs in the top end of the calculator. 


6. Press (EVAL). 


or 
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TELE will appear at the top left corner of the display. If GE appears 
to the right of TELE, the calculator passes this test. If GE doesn’t 
appear, the calculator requires service. 


To return to normal calculator operation (system halt): 


1. Press and hold (ON). 
2. Press and release the “C” key (the key with C next to it). 
3. Release (ON). The empty stack display should appear. 


Serial Loop-Back Test 


This test checks the operation of the send and receive circuits of the 
serial interface at the top of the calculator. 


To run the serial loop-back test: 


1. Turn on the calculator. 

2. Press and hold (ON). 

3. Press and release the “D” key (the key with D next to it). 

4. Release (ON). A vertical line will appear at both sides and at the 
center of the display. 

5. Temporarily connect (short) the middle two pins (pins 2 and 3) 
of the 4-pin serial connector at the top end of the calculator. Be 
careful not to bend or severely jar the pins. You must have this 
connection bridged during the entire duration of the test. 


6. Press (PRG). 


ILE will appear at the top left corner of the display. If G& 
to the right of LILLE, the calculator passes this test. If G# doesn’t 
appear, the calculator requires service. 


Note If you inadvertently short pins 1 and 2 or pins 3 
and 4 of the serial connector, the loop-back test will 
return U_LE BEGGI or H LE GEGAJ 


Bai or U LE gages (test-failed 
message), but you will not damage the calculator. 
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To return to normal calculator operation (system halt): 


1. Press and hold (ON). 
2. Press and release the “C” key (the key with C next to it). 
3. Release (ON). The empty stack display should appear. 


Limited One-Year Warranty 


What Is Covered. The calculator (except for the batteries, or damage 
caused by the batteries) and calculator accessories are warranted by 
Hewlett-Packard against defects in materials and workmanship for 
one year from the date of original purchase. If you sell your unit or 
give it as a gift, the warranty is automatically transferred to the new 
owner and remains in effect for the original one-year period. During 
the warranty period, we will repair or, at our option, replace at no 
charge a product that proves to be defective, provided you return 
the product, shipping prepaid, to a Hewlett-Packard service center. 
(Replacement may be made with a newer model of equal or better 
functionality.) 


This warranty gives you specific legal rights, and you may also have 
other rights that vary from state to state, province to province, or 
country to country. 


What Is Not Covered. Batteries, and damage caused by the batteries, 
are not covered by the Hewlett-Packard warranty. Check with the 
battery manufacturer about battery and battery leakage warranties. 


Damage caused to the HP 48 as the result of using nonapproved plug-in 
cards and plug-in accessories is not covered by the Hewlett-Packard 
warranty. 


This warranty does not apply if the product has been damaged by 
accident or misuse or as the result of service or modification by other 
than an authorized Hewlett-Packard service center. 


No other express warranty is given. The repair or replacement 
of a product is your exclusive remedy. ANY OTHER IMPLIED 
WARRANTY OF MERCHANTABILITY OR FITNESS 

IS LIMITED TO THE ONE-YEAR DURATION OF THIS 
WRITTEN WARRANTY. Some states, provinces, or countries 
do not allow limitations on how long an implied warranty lasts, 
so the above limitation may not apply to you. INNO EVENT 
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SHALL HEWLETT-PACKARD COMPANY BE LIABLE FOR 
CONSEQUENTIAL DAMAGES. Some states, provinces, or countries 
do not allow the exclusion or limitation of incidental or consequential 
damages, so the above limitation or exclusion may not apply to you. 


Products are sold on the basis of specifications applicable at the time 
of manufacture. Hewlett-Packard shall have no obligation to modify or 
update products, once sold. 


Consumer Transactions in Australia and the United Kingdom. 

The above disclaimers and limitations shall not apply to consumer 
transactions in Australia and the United Kingdom and shall not affect 
the statutory rights of consumers. 


If the Calculator Requires Service 


Hewlett-Packard maintains service centers in many countries. These 
centers will repair a calculator, or replace it with the same model or 
one of equal or better functionality, whether it is under warranty or 
not. There is a service charge for service after the warranty period. 
Calculators normally are serviced and reshipped within 5 working 
days. 


Note If the contents of your calculator’s memory are 

important, you should back up the memory on a 
f plug-in RAM card, another HP 48, or a computer 
before sending in the calculator for repair. 


m In the United States: Send the calculator to the Corvallis Service 
Center listed on the inside of the back cover. 


m In Europe: Contact your Hewlett-Packard sales office or dealer, or 
Hewlett-Packard’s European headquarters (address below) for the 
location of the nearest service center. Do not ship the calculator for 
service without first contacting a Hewlett-Packard office. 


Hewlett-Packard S.A. 

150, Route du Nant-d’Avril 
P.O. Box CH 1217 Meyrin 2 
Geneva, Switzerland 


‘elephone: 022 780.81.11 
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a In other countries: Contact your Hewlett-Packard sales office or 
dealer or write to the Corvallis Service Center (listed on the inside 
of the back cover) for the location of other service centers. If local 
service is unavailable, you can ship the calculator to the Corvallis 
Service Center for repair. 


All shipping, reimportation arrangements, and customs costs are 
your responsibility. 


Service Charge. Contact the Corvallis Service Center (inside back 
cover) for the standard out-of-warranty repair charges. This charge 
is subject to the customer’s local sales or value-added tax wherever 
applicable. 


Calculator products damaged by accident or misuse are not covered by 
the fixed charges. These charges are individually determined based on 
time and material. 


Shipping Instructions. If your calculator requires service, ship it to the 
nearest authorized service center or collection point. 


m Include your return address and a detailed description of the 
problem. Details should include ROM/RAM cards installed, error 
messages, and any peripherals connected at the time of malfunction. 

a Include proof of purchase date if the warranty has not expired. 

m Include a purchase order, check, or credit card number plus 
expiration date (VISA or MasterCard) to cover the standard repair 
charge. 

a Ship your calculator postage prepaid in adequate protective 
packaging to prevent damage. Shipping damage is not covered by 
the warranty, so we recommend that you insure the shipment. 


Warranty on Service. Service is warranted against defects in materials 
and workmanship for 90 days from the date of service. 


Service Agreements. In the U.S., a support agreement is available for 
repair and service. For additional information, contact the Corvallis 
Service Center (see the inside of the back cover). 
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Error Messages 


This appendix lists selected HP 48 messages, arranged alphabetically. 


Messages Listed Alphabetically 


Message Meaning # (hex) 

Alarm Alarm not acknowledged yet. (none) 

All Variables There are no unknown E405 

Eric variables to solve for. 

Bad Argument Tupe | One or more stack arguments 202 
were incorrect type for 
operation. 

Bad Argument Value | Argument value out of 203 
operation’s range. 

Bad Guesstes> Guess(es) supplied to HP Solve} A01 
application or ROOT lie 


outside domain of equation. 


Bad Packet Black Kermit error: Computed C01 
Chek packet checksum doesn’t 
match checksum in packet. 


Can't Edit Hull Attempted to edit a string 102 
Char containing character with code 

0. 
Circular Referenze | Attempted to store a variable 129 


name into itself. 
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Messages Listed Alphabetically (continued) 


Message 


Meaning 


# (hex) 


Eat eruM 


HALT Mot Allowed 


Illegal Purina 
MROOT 


Infinite Result 


if PF icient 


Maruman 


ir 
ai 


inconsistent Unit 


HP Solve application or ROOT 
returned same value at every 
sample point of current 
equation. 


Name of existing directory 
variable used as argument. 


Attempted to store a directory 
into itself. 


EQ must contain at least two 
equations (or programs) and 
two variables. 


Result returned by HP Solve 
application or ROOT is an 
extremum rather than a root. 


A program containing HALT 
executed while MatrixWriter 
application, DRAW, CALC, or 
HP Solve application active. 


Multiple-Equation Solver 
command attempted during 
MROOT execution. 


Attempted unit conversion 
with incompatible units. 


Math exception: Calculation 
such as 1/0 has infinite result. 


Not enough free memory to 
execute operation. 


A02 


12A 


002 


E403 


A06 


126 


E406 


B02 


305 


001 
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Messages Listed Alphabetically (continued) 


Message | Meaning # (hex) 
ficient E A Statistics command was 603 


executed when X DAT did not 
contain enough data points for 
calculation. 


The HP Solve application or A03 
ROOT was interrupted by 
(CANCEL) 


returned object of 502 


wrong type for current matrix. 


Data HP 48 does not recognize data 008 
on plug-in card, or at least one 
port on the card has never 
been used. 


Invalid Date Date argument not real D01 
number in correct format, or 
was out of range. 


Invalid Definition |Incorrect structure of equation 12C 
argument for DEFINE. 


Invelic Dimension Array argument had wrong 501 
dimensions. 
Invelic EG Attempted operation from 607 


GRAPHICS FCN menu when 
EQ did not contain algebraic, 
or attempted DRAW with 
CONIC plot type when EQ 
did not contain algebraic. 


IOPAR not a list, or one or C12 
more objects in list missing or 
invalid. 

Ire Hear Mpar variable was not created E401 
by MINIT. 
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Messages Listed Alphabetically (continued) 


Message 


Meaning 


# (hex) 


Invalid PETEAR 


Invalid Repeat 


Invedicd Seransre 
rod. 


Invalid Suntax 


Invedia Time 


Received illegal filename, or 
server asked to send illegal 
filename. 


PPAR not a list, or one or 
more objects in list missing or 
invalid. 


PRTPAR not a list, or one or 
more objects in list missing or 
invalid. 


Plot type invalid for current 
equation. 


Alarm repeat interval out of 
range. 


Invalid command received 
while in Server mode. 


HP 48 unable to execute 
OBJ—, (ENTER), or STR— due 


to invalid object syntax. 


Time argument not real 
number in correct format, or 
out of range. 


Unit operation attempted with 
invalid or undefined user unit. 


Type or structure of object 
executed as user-defined 
function was incorrect. 


Statistics command executed 
with invalid object stored in 
S DAT. 


C17 


12E 


C13 


620 


D03 


C08 


106 


D02 


B01 


103 


601 
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Messages Listed Alphabetically (continued) 


Meaning # (hex) 


Nonlinear curve fit attempted 605 
when X DAT matrix contained 
a negative element. 


Nonlinear curve fit attempted 606 
when X DAT matrix contained 
a 0 element. 


+’ PAR not list, or one or more 604 
objects in list missing or 
invalid. 

LAST STACK (>) (UNDO) pressed while that 124 
Disabled recovery feature disabled. 
LASTARG Disabled LASTARG executed while that 205 
recovery feature disabled. 
LoBat ¢ J Replace calculator batteries (none) 
£3, or replace plug-in card 
batteries ¿F13 or (FES. 


Low Battery System batteries too low to C14 
safely print or perform I/O. 

Memory Clear HP 48 memory was cleared. 005 

Name Conflict The | (where) function 13C 


attempted to assign a value to 
the variable of integration or 
summation index. 


Math exception: Calculation 302 
returned negative result, 
between 0 and —MINR. 


SOLVE, DRAW, or RCEQ 104 
executed with nonexistent EQ. 


Ñ 


Error Messages B-5 


Messages Listed Alphabetically (continued) 


into a backup object when its 
stored object was in use. 


Message Meaning # (hex) 
Plot or HP Solve application 609 
executed with nonexistent EQ. 
Insufficient free memory in 00B 
specified RAM port. 

Not enough free memory to 101 
save copy of the stack. LAST 

STACK is automatically 

disabled. 

i Stack objects displayed by 131 
type only due to low memory 
condition. 

Ho stat date tea No data stored in X DAT. 60F 

plot 

Momc-Emedy Attempted to purge nonempty 12B 

Directory directory. 

Hon-Real Result Execution of HP Solve 12F 
application, ROOT, DRAW, or 
Í returned result other than 
real number or unit. 

Monexistent Alari Alarm list did not contain D04 
alarm specified by alarm 
command. 

Honesistent DAT Statistics command executed 602 
when 3} DAT did not exist. 

Ubject Discarded Sender sent an EOF (Z) packet} COF 
with a “D” in the data field. 

Object In Use Attempted PURGE or STO 009 


B-6 Error Messages 


Messages Listed Alphabetically (continued) 


Message 


Meaning 


# (hex) 


Chee? | eug 


Parity Errar 


Port 


Closed 


Pori Mob Auwailaeble 


Positive Under? pow 


Attempted to access a 
nonexistent backup object or 
library. 


Function value, root, 
extremum, or intersection was 
not visible in current display. 


One or more objects must be 
purged to continue calculator 
operation. 


Math exception: Calculation 
returned result greater in 
absolute value than MAXR. 


Received bytes’ parity bit 
doesn’t match current parity 
setting. 


Possible IR or serial hardware 
failure. Run self-test. 


Used a port command on an 
empty or nonexistent port, or 
one containing ROM instead of 
RAM. (Ports 1 and 2 don’t 
exist in the HP 48G.) 


Attempted to execute a server 
command that itself uses the 
I/O port. 


Math exception: Calculation 
returned positive result, 
between 0 and MINR. 


00C 


61F 


135 


303 


C05 


c09 


00A 


301 
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Messages Listed Alphabetically (continued) 


Message 


Meaning 


# (hex) 


Foner Lost 


pr 


Receive Buffer 


Cher rur 


kezelve Error 


Sinale Equation 


Calculator turned on following 
a power loss. Memory may 
have been corrupted. 


Received a packet whose length 
was shorter than a null packet. 


Maximum packet length 
parameter from other machine 
is illegal. 


Kermit: More than 255 bytes 
of retries sent before HP 48 
received another packet. 


SRECV: Incoming data 
overflowed the buffer. 


UART overrun or framing 
error. 


HP Solve application or ROOT 
unable to find point at which 
current equation evaluates to 
zero, but did find two 
neighboring points at which 
equation changed sign. 


Only one equation has been 
supplied to the 
Multiple-Equation Solver. 


006 


C07 


C04 


C03 


A05 


E402 


B-8 Error Messages 


Messages Listed Alphabetically (continued) 


Message Meaning # (hex) 


Printing to serial port: C02 
Received XOFF and timed out 
waiting for XON. 


Kermit: Timed out waiting for 
packet to arrive. 


Command required more 201 
arguments than were available 
on stack. 


=] 
Er 
22 

i 
th 
E 
= 
sft 
a 
oe 

fi 


led Ten successive attempts to C06 
receive a good packet were 
unsuccessful. 


ISOL failed because specified 130 
name absent or contained in 
argument of function with no 
inverse. 


Unable toa Isolat: 


iT 


Undefined Constant |The name supplied to CONST E129 
is not in the Constants Library. 


Undefined Local Executed or recalled local 003 
Harme name for which corresponding 
local variable did not exist. 


Undefined Hame Executed or recalled global 204 
name for which corresponding 
variable does not exist. 


Undefined Result Calculation such as 0/0 304 
generated mathematically 
undefined result. 


Uneefimed LIE Executed an XLIB name when 004 
Harme specified library absent. 
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Messages Listed Alphabetically (continued) 


Message Meaning # (hex) 
krona Frcqureernt User-defined function 128 
Count evaluated with an incorrect 
number of parenthetical 
arguments. 
Zeru Result returned by the HP A04 


Solve application or ROOT is a 
root (a point at which current 
equation evaluates to zero). 


B-10 Error Messages 


No. Name No. Name 

0 Last Menu 27 | PRG BRCH FOR 
1 CST 28 | EDIT 

2 VAR 29 | PRG BRCH DO 
3 MTH 30 | SOLVE ROOT SOLVR 
4 MTH VECTR 31 | PRG BRCH WHILE 
5 MTH MATR 32 | PRG TEST 

6 MTH MATR MAKE 33. | PRG TYPE 

7 MTH MATR NORM 34 | PRG LIST 

8 MTH MATR FACTR 35 | PRG LIST ELEM 
9 MTH MATR COL 36 | PRG LIST PROC 
10 |MTH MATR ROW 37 | PRG GROB 

11 | MTH LIST 38 | PRG PICT 

12 | MTH HYP 39 | PRG IN 

13 | MTH PROB 40 | PRG OUT 

14 | MTH REAL 41 | PRG RUN 

15 | MTH BASE 42 | UNITS Catalog 
16 | MTH BASE LOGIC 43 | UNITS LENG 

17 |MTH BASE BIT 44 | UNITS AREA 

18 | MTH BASE BYTE 45 | UNITS VOL 

19 |MTH FFT 46 | UNITS TIME 

20 | MTH CMPL 47 | UNITS SPEED 
21 | MTH CONS 48 | UNITS MASS 

22 |PRG 49 | UNITS FORCE 
23 | PRG BRCH 50 | UNITS ENRG 

24 |PRG BRCH IF 51 | UNITS POWR 
25 |PRG BRCH CASE 52 | UNITS PRESS 
26 | PRG BRCH START 


Menus C-1 


No. Name No. Name 

53 | UNITS TEMP 87 | PLOT STAT 

54 | UNITS ELEC 88 |PLOT STAT PTYPE 
55 | UNITS ANGL 89 | PLOT STAT SPAR 
56 | UNITS LIGHT 90 | PLOT STAT SPAR 
57 | UNITS RAD MODL 

58 | UNITS VISC 91 |PLOT STAT DATA 
59 |UNITS Commands 92 |PLOT FLAG 

60 |PRG ERROR IFERR 93 |SYMBOLIC 

61 |PRG ERROR 94 | TIME 

62 |CHAR 95 | TIME ALRM 

63 | MODES 96 |STAT 

64 |MODES FMT 97 |STAT DATA 

65 | MODES ANGL 98 |STAT EPAR 

66 | MODES FLAG 99 |STAT SPAR MODL 
67 | MODES KEYS 100 |STAT 1VAR 

68 |MODES MENU 101 |STAT PLOT 

69 | MODES MISC 102 |STAT FIT 

70 | MEMORY 103 | STAT SUMS 

71 | MEM DIR 104 |1/O 

72 | MEM ARITH 105 |1/O SRVR 

73 |STACK 106 |1/O IOPAR 

74 | SOLVE 107 |1/O PRINT 

T5 |SOLVE ROOT 108 |1/O PRINT PRTPA 
76 |SOLVE DIFFE 109 |1/O SERIA 

T7 |SOLVE POLY 110 | LIBRARY Commands 
78 | SOLVE SYS 111 | LIBRARY PORTS 
|| PONE NM 112 | LIBRARY Catalog 
80 |SOLVE TVM SOLVR 113 | EQLIB 

oe ee 114 | EQLIB EQLIB 
eee 115 | EQLIB COLIB 

> ae a 116 |EQLIB MES 

85 |PLOT 3D PTYPE E QED VRS 

86 | PLOT 3D VPAR 


C-2 Menus 


ystem Flags 


This appendix lists the HP 48 system flags in functional groups. You 
can set, clear, and test all flags. The default state of the flags is 
clear—except for the Binary Integer Wordsize flags (flags —5 through 


—10). 
System Flags 

Flag Description 

—1 | Principal Solution. 
Clear: QUAD and ISOL return a result representing all 
possible solutions. 
Set: QUAD and ISOL return only the principal solution. 

—2 |Symbolic Constants. 
Clear: Symbolic constants (e, i, 7, MAXR, and MINR) 
retain their symbolic form when evaluated, unless the 
Numerical Results flag —3 is set. 
Set: Symbolic constants evaluate to numbers, regardless of 
the state of the Numerical Results flag —3. 

—3 | Numerical Results. 
Clear: Functions with symbolic arguments, including 
symbolic constants, evaluate to symbolic results. 
Set: Functions with symbolic arguments, including symbolic 
constants, evaluate to numbers. 

—4 | Not used. 

—5 | Binary Integer Wordsize. 

thru | Combined states of flags —5 through —10 set the wordsize 

—10 | from 1 to 64 bits. 
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System Flags (continued) 


Flag Description 

—11 | Binary Integer Base. 

and |HEX: —11 set, —12 set. DEC: —11 clear, —12 clear. 

—12 | OCT: —11 set, —12 clear. BIN: —11 clear, —12 set. 

—13 | Not used. 

—14 | Financial Payment Mode. 
Clear: TVM calculations assume end-of-period payments. 
Set: TVM calculations assume beginning-of-period payments. 

—15 | Rectangular: —16 clear. 

and | Polar/Cylindrical: —15 clear, —16 set. 

—16 | Polar/Spherical: —15 set, —16 set. 

—17 | Degrees: —17 clear, —18 clear. 

and | Radians: —17 set. 

—18 | Grads: —17 clear, —18 set. 

—19 | Clear:—+V2 and (@)(2D) create a 2-dimensional vector from 2 
real numbers. 
Set:—V2 and (g®)(2D) create a complex number from 2 real 
numbers. 

—20 | Underflow Exception. 
Clear: Underflow exception returns 0, sets flag —23 or —24. 
Set: Underflow exception treated as an error. 

—21 | Overflow Exception. 
Clear: Overflow exception returns +9.99999999999E499 and 
sets flag —25. 
Set: Overflow exception treated as an error. 

—22 | Infinite Result Exception. 
Clear: Infinite result exception treated as an error. 
Set: Infinite result exception returns +9.99999999999E499 
and sets flag —26. 

—23 | Negative Underflow Indicator. 

—24 | Positive Underflow Indicator. 

—25 | Overflow Indicator. 

—26 | Infinite Result Indicator. 


When an exception occurs, corresponding flag (—23 through 
—26) is set only if the exception is not treated as an error. 
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System Fiags (continued) 


Flag 


Description 


—27 


Display of symbolic complex numbers. 

Clear: Displays symbolic complex numbers in coordinate 
form (Le. ) fea? '). 

Set: Displays symbolic complex numbers using ‘i' (Le. 
hsehugei'). 


—28 


Simultaneous Plotting of Multiple Functions. 
Clear: Multiple equations are plotted serially. 
Set: Multiple equations are plotted simultaneously. 


—29 


—30 


—31 


—32 


—33 


Draw Axes. 

Clear: Axes are drawn for two-dimensional and statistical 
plots. 

Set: Axes are not drawn for two-dimensional and statistical 
plots. 

Not used. 


Curve Filling. 


Clear: Curve filling between plotted points enabled. 
Set: Curve filling between plotted points suppressed. 


Graphics Cursor. 
Clear: Graphics cursor always dark. 


Set: Graphics cursor dark on light background and light on 
dark background. 


I/O Device. 
Clear: 1/O directed to serial port. 
Set: 1/O directed to IR port. 


—34 


Printing Device. 
Clear: Printer output directed to IR printer. 
Set: Printer output directed to serial port if flag —33 is clear. 


I/O Data Format. 
Clear: Objects transmitted in ASCII form. 
Set: Objects transmitted in binary (memory image) form. 
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System Flags (continued) 


Flag 


Description 


—36 


I/O Receive Overwrite. 

Clear: If file name received by HP 48 matches existing 

HP 48 variable name, new variable name with number 
extension is created to prevent overwrite. 

Set: If file name received by HP 48 matches existing HP 48 
variable name, existing variable is overwritten. 


—37 


Double-Spaced Printing. 
Clear: Single-spaced printing. 
Set: Double-spaced printing. 


—38 


Line Feed. 
Clear: Linefeed added at end of each print line. 
Set: No linefeed added at end of each print line. 


—40 


-39 | I/O Messages. 


Set: I/O messages suppressed. 


Clear: I/O messages displayed. 


Clock Display. 
Clear: Clock is not displayed. 


Set: Ticking clock displayed at all times. 
—41 | Clock Format. 


Clear: 12-hour clock. 
Set: 24-hour clock. 


z 


—42 


Date Format. 
Clear: MM/DD/YY (month/day/year) format. 
Set: DD.MM.YY (day.month.year) format. 


—43 


Repeat Alarms Not Rescheduled. 

Clear: Unacknowledged repeat appointment alarms 
automatically rescheduled. 

Set: Unacknowledged repeat appointment alarms not 
rescheduled. 


—44 


Acknowledged Alarms Saved. 
Clear: Acknowledged appointment alarms deleted from 
alarm list. 


Set: Acknowledged appointment alarms saved in alarm list. 
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System Flags (continued) 


Flag Description 
—45 |Number of Decimal Digits. 
thru | Combined states of flags —45 through —48 sets number of 
—48 |decimal digits in Fix, Scientific, and Engineering modes. 
—49 | Number Display Format. 
and | Standard: —49 clear, —50 clear. 
—50 | Fix: —49 set, —50 clear. 
Scientific: —49 clear, —50 set. 
Engineering: —49 set, —50 set. 
—51 | Fraction Mark. 
Clear: Fraction mark is . (period). 
Set: Fraction mark is , (comma). 
—52 | Single-Line Display. 
Clear: Display gives preference to object in level 1, using up 
to four lines of stack display. 
Set: Display of object in level 1 restricted to one line. 
—53 | Precedence. 


Clear: Certain parentheses in algebraic expressions 
suppressed to improve legibility. 


Set: All parentheses in algebraic expressions displayed. 


Tiny Array Elements. 

Clear: Singular values computed by RANK (and other 
commands that compute the rank of a matrix) that are more 
than 1 x 10°! times smaller than the largest computed 
singular value in the matrix are converted to zero. 
Automatic rounding for DET is enabled. 

Set: Small computed singular values (see above) not 
converted. Automatic rounding for DET is disabled. 


—59 


Last Arguments. 
Clear: Command arguments saved. 


Set: Command arguments not saved. 


—56 


Error Beep. 
Clear: Error and BEEP-command beeps enabled. 


Set: Error and BEEP-command beeps suppressed. 
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System Flags (continued) 


Flag Description 
—57 | Alarm Beep. 
Clear: Alarm beep enabled. 


Set: Alarm beep suppressed. 


—58 | Verbose Messages. 

Clear: Parameter variable data automatically displayed. 
Set: Automatic display of parameter variable data is 
suppressed. 


—59 | Fast Browser Display. 

Clear: Variable Browser shows variable names and contents. 
Set: Variable Browser shows variable names only. 

—60 | Alpha Lock. 


Clear: Single-Alpha activated by pressing (@) once. Alpha 
lock activated by pressing (a) twice. 


Set: Alpha lock activated by pressing (@) once. (Single-Alpha 
not available.) 


—61 | User-Mode Lock. 
Clear: 1-User mode activated by pressing (#)(USER) once. 
User mode activated by pressing ()(USER) twice. 
Set: User mode activated by pressing (;)(USER) once. 


(1-User mode not available.) 

—62 | User Mode. 

Clear: User mode not active. 

Set: User mode active. 

—63 | Vectored (ENTER). 

Clear: evaluates command line. 

Set: User-defined activated. 

—64 | Index Wrap Indicator. 

Clear: Last execution of GETI or PUTI did not increment 
index to first element. 

Set: Last execution of GETI or PUTI did increment index to 
first. element. 
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ble of Units 


HP 48 Units 
Unit (Full Name) Value in SI Units 
a (Are) 100 m? 
A (Ampere) 1A 


acre (Acre) 

arcmin (Minute of arc) 
arcs (Second of arc) 
atm (Atmosphere) 

au (Astronomical unit) 
A (Angstrom) 

b (Barn) 

bar (Bar) 

bbl (Barrel) 

Bq (Becquerel) 

Btu (International Table Btu) 
bu (Bushel) 

°c (Degree Celsius) 

c (Speed of light) 

c (Coulomb) 

cal (Calorie) 

cd (Candela) 

chain (Chain) 

Ci (Curie) 

ct (Carat) 

cu (US cup) 

° (Degree) 

d (Day) 

aB (Decibel) 


4046.87260987 m? 
2.90888208666 x 10°74 r 
4.8481368111 x 10% r 
101325 kg/m-s? 
1.495979 x 1012 m 

1 x 107° m 

1 x 1028 m? 

100000 kg/m-s? 
158987294928 m? 

1 1/s 

1055.05585262 kg-m?/s? 
03523907 mê 

1 K or 274.15 K 
299792458 m/s 

1 A's 

4.1868 kg-m? /s? 

1 cd 

20.1168402337 m 

3.7 x 101° 1/s 

.0002 kg 

2.365882365 x 1074 m? 
1.74532925199 x 107? r 
86400 s 

1 
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HP 48 Units (continued) 


Unit (Full Name) 


dyn (Dyne) 

erg (Erg) 

eV (Electron volt) 

F (Farad) 

°F (Degrees Fahrenheit) 
fath (Fathom) 

fbm (Board foot) 

fc (Footcandle) 

Fdy (Faraday) 

fermi (Fermi) 

flam (Footlambert) 

ft (International foot) 
ftUS (Survey foot) 

g (Gram) 

ga (Standard freefall) 
gal (US gallon) 

galc (Canadian gallon) 
galUK (UK gallon) 

gf (Gram-force) 

gmol (Gram-mole) 
grad (Grade) 

grain (Grain) 

ay (Gray) 

H (Henry) 

ha(Hectare) 

h (Hour) 

hp (Horsepower) 

Hz (Hertz) 

in (Inch) 

inHg (Inches of mercury, 0°C) 
inH20 (Inches of water, 60°F) 
J (Joule) 

K (Kelvins) 

kg (Kilogram) 


i Value in SI Units 


.00001 kg-m/s? 

.0000001 kg-m? /s? 
1.60217733 x 10719 ke-m? /s? 
1 A?-s*/kg-m? 


0.555555555556 K or 255.927777778 K 


1.82880365761 m 
002359737216 m 
10.7639104167 cd-sr/m? 
96487 A-s 

1x 107% m 
3.42625909964 cd/m? 
.3048 m 

.304800609601 m 

.001 kg 

9.80665 m/s? 
003785411784 m? 
.00454609m* 
004546092 m? 
.00980665 kg-m/s? 

1 mol 

1.57079632679 x 10°? r 
00006479891 kg 

1 m?/s? 

1 kg-m?/A?-s? 

10000 m? 

3600 s 

745.699871582 kg-m?/s® 
11/s 

.0254 m 

3386.38815789 kg/m-s? 
248.84 kg/m-s* 

1 kgm? /s? 

1K 

1 kg 
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HP 48 Units (continued) 


Unit (Full Name) 


Value in SI Units 


kip (Kilopound-force) 
knot (Nautical miles per hour) 
kph (Kilometers per hour) 
1 (Liter) 

lam (Lambert) 

1b (Avoirdupois pound) 
1bf (Pound-force) 
lbmol (Pound-mole) 
lbt (Troy pound) 

1m (Lumen) 

Lx (Lux) 

lyr (Light year) 

m (Meter) 

u (Micron) 

mho (Mho) 

mi (International mile) 
mil (Mil) 

min (Minute) 

miUs (US statute mile) 
mmHg (Millimeter of mercury (torr), 0°C) 
mol (Mole) 

mph (Miles per hour) 

N (Newton) 

nmi (Nautical mile) 

í (Ohm) 

oz (Ounce) 

ozf1 (US fluid ounce) 
ozt (Troy ounce) 

ozUK (UK fluid ounce) 
P (Poise) 

Pa (Pascal) 

pe (Parsec) 

pdl (Poundal) 

ph (Phot) 


4448.22161526 kg-m/s” 
514444444444 m/s 
277777777778 m/s 
.001 m? 

3183.09886184 cd/m? 
45359237 kg 
4.44822161526 kg-m/s” 
453.59237 mol 
.3732417216 kg 

1 cd-sr 

1 cd-sr/m? 
9.46052840488 x 1015 m 
im 

1x 107° m 

1 A?-s* /kg-m? 
1609.344 m 

0000254 m 

60 s 

1609.34721869 m 
133.322368421 kg/m-s? 
1 mol 

.44704 m/s 

1 kg-m/s? 

1852 m 

1 kg-m?/A?-s? 
.028349523125 kg 
2.95735295625 x 1075 m 
0311034768 kg 
2.8413075 x 107° mê 
1 kg/m-s 
1 kg/m-s? 
3.08567818585 x 101° m 
138254954376 kg-m/s? 
10000 cd-sr/m? 
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HP 48 Units (continued) 


Unit (Full Name) 


Value in SI Units 


pk (Peck) 

psi (Pounds per square inch) 
pt (Pint) 

qt (Quart) 

x (Radian) 

R (Roentgen) 

°R (Degrees Rankine) 
rad (Rad) 

rd (Rod) 

rem (Rem) 

rpm (Revolutions per minute) 
s (Second) 

S (Siemens) 

sb (Stilb) 

slug (Slug) 

sr (Steradian) 

st (Stere) 

St (Stokes) 

Sv (Sievert) 

t (Metric ton) 

T (Tesla) 

tbsp (Tablespoon) 
therm (EEC therm) 
ton (Short ton) 

tonUK (Long (UK)) 
torr (Torr (mmHg)) 
tsp (Teaspoon) 

u (Unified atomic mass) 
v (Volt) 

W (Watt) 

Wb (Weber) 

yd (International yard) 
yr (Year) 


.0088097675 m? 
6894.75729317 kg/m-s? 
000473176473 m° 
000946352946 m? 

lr 

.000258 A-s/kg 
0.555555555556 K 

.01 m? /s? 
5.02921005842 m 

01 m?/s? 
0166666666667 1/s 
ls 

1 A?-s* /kg-m? 

10000 cd/m? 
14.5939029372 kg 

1sr 

1m? 

.0001 m?/s 

1 m?/s? 

1000 kg 

1 kg/A-s? 
1.47867647813 x 107° mê 
105506000 kg-m?/s? 
907.18474 kg 
1016.0469088 kg 
133.322368421 kg/ms? 
4.92892159375 x 107° m? 
1.6605402 x 107?" kg 
1 kg-m?/A-s* 

1 kgm? /s? 

1 kg-m?/A-s? 

.9144 m 
31556925.9747 s 
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e of Built-In Equations 


The Equation Library consists of 15 subjects (corresponding to the 
sections in the table below) and more than 100 titles. The numbers 
in parentheses below indicate (number of equations in the set, number 
of variables in the set). There are a total of 315 equations using 396 
variables. 


Subjects and Titles 


1: Columns and Beams (14,20) 


1: Elastic Buckling (4,8) 6: Simple Shear (1,7) 

2: Eccentric Columns (2,11) 7: Cantilever Deflection (1,10) 

3: Simple Deflection (1,9) 8: Cantilever Slope (1,10) 

4: Simple Slope (1,10) 9: Cantilever Moment (1,8) 

5: Simple Moment (1,8) 10: Cantilever Shear (1,6) 

2: Electricity (42,56) 

1: Coulomb’s Law (1,5) 13: Capacitor Charge (1,3) 

2: Ohm’s Law and Power (4,4) 14: DC Inductor Voltage (3,8) 

3: Voltage Divider (1,4) 15: RC Transient (1,6) 

4: Current Divider (1,4) 16: RL Transient (1,6) F: 
5: Wire Resistance (1,4) 17: Resonant Frequency (4,7) , 
6: Series and Parallel R (2,4) 18: Plate Capacitor (1,4) 

T: Series and Parallel C (2,4) 19: Cylindrical Capacitor (1,5) 

8: Series and Parallel L (2,4) 20: Solenoid Inductance (1,5) 

9: Capacitive Energy (1,3) 21: Toroid Inductance (1,6) 

10: Inductive Energy (1,3) 22: Sinusoidal Voltage (2,6) 

11: RLC Current Delay (5,9) 23: Sinusoidal Current (2,6) 


12: DC Capacitor Current (3,8) 


Table of Built-In Equations F-1 


Subjects and Titles (continued) 


3: Fluids (29,29) 

1: Pressure at Depth (1,4) 3: Flow with Losses (10,17) 

2: Bernoulli Equation (10,15) 4: Flow in Full Pipes (8,19) 
4: Forces and Energy (31,36) 

1: Linear Mechanics (8,11) 5: 1D Elastic Collisions (2,5) 
2: Angular Mechanics (12,15) 6: Drag Force (1,5) 

3: Centripetal Force (4,7) 7: Law of Gravitation (1,4) 

4: Hooke’s Law (2,4) 8: Mass-Energy Relation (1,3) 
5: Gases (18,26) 

1: Ideal Gas Law (2,6) 5: Isentropic Flow (4,10) 

2: Ideal Gas State Change (1,6) 6: Real Gas Law (2,8) 

3: Isothermal Expansion (2,7) 7: Real Gas State Change (1,8) 
4: Polytropic Processes (2,7) 8: Kinetic Theory (4,9) 

6: Heat Transfer (17,31) 

1: Heat Capacity (2,6) 5: Conduction + 

2: Thermal Expansion (2,6) Convection (4,14) 

3: Conduction (2,7) 6: Black Body Radiation (5,9) 
4: Convection (2,6) 

7: Magnetism (4,14) 

1: Straight Wire (1,5) 3: B Field in Solenoid (1,4) 

2: Force between Wires (1,6) 4: B Field in Toroid (1,6) 

8: Motion (22,24) 

1: Linear Motion (4,6) 5: Circular Motion (3,5) 

2: Object in Free Fall (4,5) 6: Terminal Velocity (1,5) 

3: Projectile Motion (5,10) 7: Escape Velocity (1,14) 

4: Angular Motion (4,6) 


F-2 Table of Built-In Equations 


Subjects and Titles (continued) 


9: Optics (11,14) 

1: Law of Refraction (1,4) 
2: Critical Angle (1,3) 

3: Brewster’s Law (2,4) 


4: Spherical Reflection (3,5) 
5: Spherical Refraction (1,5) 
6: Thin Lens (3,7) 


10: Oscillations (17,17) 


1: Mass-Spring System (3,5) 
2: Simple Pendulum (3,4) 
3: Conical Pendulum (4,6) 


4: Torsional Pendulum (3,7) 
5: Simple Harmonic (4,8) 


11: Plane Geometry (31,21) 
1: Circle (5,7) 

2: Ellipse (5,8) 

3: Rectangle (5,8) 


4: Regular Polygon (6,8) 
5: Circular Ring (4,7) 
6: Triangle (6,10) 


12: Solid Geometry (18,12) 

1: Cone (5,9) 

2: Cylinder (5,9) 

13: Solid State Devices (33,53) 


1: PN Step Junctions (8,19) 
2: NMOS Transistors (10,23) 


14: Stress Analysis (16,28) 


1: Normal Stress (3,7) 
2: Shear Stress (3,8) 


3: Parallelepiped (4,9) 
4: Sphere (4,7) 


3: Bipolar Transistors (8,14) 
4: JFETs (7,15) 


3: Stress on an Element (3,7) 
4: Mohr’s Circle (7,10) 


15: Waves (12,15) 


1: Transverse Waves (4,9) 
2: Longitudinal Waves (4,9) 


3: Sound Waves (4,8) 


Table of Built-In Equations F-3 


peration Index 


This index contains reference information for all operations in the 
HP 48. For each operation, this index shows: 


m Name. The name associated with the operation. Operations 
that can be included in programs (commands) are shown in all 
uppercase. 


a Description. What the operation does. If the operation expects 
arguments from the stack, the description includes the variables 
which represent arguments in levels 1 (x), 2 (y), 3 (2), 4 (t) and 5 


(v). 
m Type. The type of operation is given by one of the following codes: 


Code Description 
O Operation. Any action built into the calculator that is 


represented by a name or a key. 


y 


Command. Any programmable operation. 


F Function. Any command that can be included in algebraic 
objects. 


A Analytic Function. A function for which the HP 48 provides 
an inverse and derivative. 


m Keys. The keys to access the operation. Operations that aren't 
key-accessible are identified by “Must be typed in.” 


a Page. Where to find a description of the operation. 


Operations whose names contain both alpha and special characters 
are listed alphabetically. Operations whose names contain special 
characters only are listed at the end of the index. 


Operation Index G-1 


ACKALL 


cC (4)C@IME) ALEM ALE 
Acknowledges all past due alarms. 


C (ACME) ALEN ATER 


Name, Key, Description, Type, and Keys Page 
or Label 
HA Associate left. 20-23 
o (EQUATION) (S) RULES + A 
faa) A Executes = Fi until no change. 20-26 
O (4) (EQUATION) (Q RNL eA 
A— Associate right. 20-23 
o (#) (EQUATION) (4) E +A 
fane Executes A+ until no change. 20-26 
o (#)(EQUATION) (4) RULES (e) 
ABS Absolute value of an object (x). 12-9 
REAL 
HATE HORM 
MPL AES 
F VECTR AES 
ACK Acknowledges displayed past due alarm. 26-4 


balance for a number of payments for the financial 
scenario currently stored in the TVM variables 
(41/YR, PMT, FV, and PV). 


O SOLVE] Solve finance... 
APE 


FPL 


ACOS Arc cosine of a number (2). 12-2 
A GCS) 
ACOSH Arc hyperbolic cosine of a number (2). 12-3 
A HYP ACOSH 
ADD Adds two lists (x and y) element by element. 17-3 
c LIST AbD 
AF Add fractions. 20-25 
o ()(EQUATION)@) RULES AF 
ALOG Common (base 10) antilogarithm of a number (x). 12-2 
a @@ 
AMORT Calculates the amount of principal, interest, and 18-19 


G-2 Operation Index 


Name, Key, Description, Type, and Keys Page 
or Label 


AMORT Calculates the amount of principal, interest, and H-1 
balance for a number (x) of payments for the 
financial scenario currently stored in the TVM 
variables (%I/YR, PMT, FV, and PV). 


c OCM Tn 


AMRT Calculates the amount of principal, interest, and 18-19 
balance for a number (x) of payments for the 
financial scenario entered in the interactive solver. 


o OCM T 


SOLVE 


AND Logical AND of two expressions (x and y) that 15-4 
evaluate to 1 or 0 or binary AND combining two 
integers (x and y) or two strings (x and y). 


MTH) BASE Le AHD H-1 
F TESI AHD 


ANIMATE Successively displays a specified number (x) of 9-10 
GROBs (y, z ... ) that are on the stack. 


C GEGE AMIR 


APPLY Creates an unevaluated expression combining an H-1 
unevaluated function name (r) with a list (y) of 
evaluated arguments. 


——— F (4)(SYMBOLIC APPics 


ARC Draws arc in PICT counterclockwise from one 9-8 
angle (y) to another (x) along the circle with a 
center at z and radius t. 


C EPET (oR RE 
ARCHIVE Makes backup copy of HOME directory. 28-5 


C  (4)(MEMORY) (NXT) RECHT 


AREA Calculates and displays area under function graph 22-10 
between two r-values specified by the mark and 
cursor; returns area to stack. 


o QUT) F 


ARG Returns polar angle (8) of a complex number (x). 12-13 


ARRY— Returns array elements to stack. H-2 
C Must be typed in. 


Operation Index G-3 


Name, Key, 
or Label 


Description, Type, and Keys 


Page 


—ARRY 


Combines numbers into array. 


c 


are 
ea 


14-4 


ASIN 


Arc sine of a number (z). 


A QED 


12-2 


ASINH 


Arc hyperbolic sine of number (1). 


A ASIMH 


ASN 


Assigns an object (y) to a user-key (2). 


c QU 


30-5 


ASR 


Shifts a binary integer (x) one bit to the right. 


15-5 


ATAN 


Arc tangent of a number (7v). 


A QN 


ATANH 


ATICK 


ATTACH 


AUTO 


Arc hyperbolic tangent of a number (z). 
A HEP ATA 
Sets the axes tick mark annotation by a list (x) 


containing the axes tick mark interval in user-units 
or pixels. 


c ()@LOT) FFAR @RDATICE 


Attaches a library (x) to current directory. 


c GEARY) GED attrac 


Auto-scales y-axis. 


c DELNA ATO 


28-8 


AXES 


Specifies the plot axes using a list (z) containing 
the coordinates of axes intersection, the tick mark 
interval, or the axes labels, or any combination of 
the above. 


24-1 


BAR 


Selects BAR plot type. 


C ELON GaN stat P 


23-19 


BARPLOT 


Draws bar plot of data in X DAT. 


c @G Lor 


21-7 


BAUD 


Sets the baud rate to r. 


c 0o [GFR 


27-15 


G-4 Operation Index 


Name, Key, 
or Label 


Description, Type, and Keys 


BEEP 


Sounds beep at a frequency (y Hz) for x seconds. 


c OUT QXD BEEF 


BEG 


Toggles payment mode between Beginning-, or 
End-, of-Month. See TVMBEG and TVMEND for 
the command form of this operation. 


o (4)GOLVE) TYN BEG 


BESTFIT 


Selects statistics model yielding largest correlation 
coefficient (absolute value) and executes LR. 


c ()GIAD IFAR HODL 


BESTE 


BIN 


Sets binary base. 


C BASE BIH 


15-1 


BINS 


BLANK 


BOX 


Sorts elements in independent variable column of 
XDAT into a number (x + 2) of “bins” of a 
designated width (y), starting with a minimum 
data value (z). 


C GTT VAR BINS 


Creates blank graphics object, y pixels wide by x 
pixels high. 


Draws box with opposite corners defined by 
coordinates x and y. 


c PICT 


BOS 


9-9 


C GROE ELAH 


amortization to the PV variable in preparation for 
amortizing the next group of payments. 


oO œ SOLVE) Solve finance... H 


E pa i 


BOX Draws box with opposite corners defined by mark 9-3 
and cursor. 
o @ EDIT RÜR 
BOXZ Toggles expanding-box drawing mode on and off. 22-7 
O (4)(PICTURE) 200M 
BUFLEN Returns number of characters in serial buffer. 27-19 
c o SER SUELE 
BYTES Returns object size (in bytes) and checksum for an H-2 
object (x). 
cC (4)MEMORY)JEVTES 
B—PV Transfers the remaining balance after an 18-20 


Operation Index G-5 


Name, Key, Description, Type, and Keys Page 
or Label 
B>R Converts a binary integer (x) to a real number. 15-3 
Cc BoE 
CALC Copies the contents of the current field to the 6-5 
stack and displays the stack. Used to make 
side-calculations or take side-trips to other parts of 
the calculator while working within an input form. 
O [input form] CALC 
CANCL Erases the command line and cancels the entry in 6-7 
process or exits an input form without executing 
its main action. 
[input form] (CANCEL 
O [input form] RAHCL 
CASE Begins CASE structure. 29-11 
Cc ERCH CASE EASE 
(4) CASE Types CASE THEN END END. 29-11 
o (FRG) ERCH (@) CASE 
()CASE |Types THEN END. 29-11 


o EECH (@) CASE 


CEIL Returns next integer greater than z. 12-9 
| F REAL TEIL 
CENTR Sets center of plot display at specified (x, y) H-3 
coordinates. 
C ()(PLOT) FFARR CEHT 
ios CF Clears flag v. T as 
ERE CED OD ESE 
c QUD FLAG cF 
%CH Returns % change from y to v. 12-9 
F REAL osSCH 
CHK Toggles the checkmark field on and off. 6-4 
O [input form] oat 
CHOOS Displays a choose box with additional possible 6-3 


entries relevant to the current field. 
O [input form] PHOS 


G-6 Operation Index 


Name, Key, 
or Label 


Description, Type, and Keys 


Page 


CHOOSE 


Creates a user-defined choose box from a title 
string (z), a list of objects (y), and the number (x) 
of the default object to be highlighted. 


c rH C 


H-3 


CHR 


Converts a character code (x) to one-character 
string. 


C TYRE CHE 


CIRCL 


Draws circle with center at the mark and radius 
equal to the distance from cursor to mark. 


o MWAH) EDIT CIREL 


9-4 


CKSM 


Selects checksum error-detection scheme («). 


c QED 10F 


CLEAR 


Clears stack. 


C (CLEAR) or (4)(CLEAR) 


CLK 


CLKADJ 


Turns the clock display on and off. 


o (4)(MODES) MISC CLE 


Adds vx clock ticks (1 tick = ans second) to 
system time. 


C DCMI NINAD CLEA 


CLLCD 


= e 


Blanks stack display (but doesn’t clear the stack 
itself). 


CLOSEIO 


C OUTS GELE 


Closes I/O port. 


c QOD case 


CLE 


Purges statistical data in X DAT. 


c (4)GTAT) PATA CLE 


CLUSR 


Purges all user variables in current directory. 


C Must be typed in. 


CLVAR 


Purges all user variables in current directory. 


C Must be typed in. 


CNCT 


Toggles the flag controlling whether plotted points 
are connected with line segments. 


0 GOD GD FL 


CHO 


CNRM 


Calculates column norm of an array (2). 


EF 


14-8 


Operation Index G-7 


COL 


C HATE COL -CGL 
Transforms a series of x column vectors (y, z, etc.) 


into a matrix containing those vectors as its 
columns. 


C (MTH) HATE coL cole 


Name, Key, Description, Type, and Keys Page 
or Label 

CNTR Redraws graph with center at current cursor 22-8 
position. 
o (#)(PICTURE) ET CHIR 

—COL Transforms a matrix (z) into a series of column 14-4 
vectors. 
c HATE CUL -CoL 

+COL Inserts a row of zeros at current column in 8-8 
MatrixWriter application. 
O (>) (MATRIX COL 

COL+ Inserts a column vector (y) into an array (z) as 14-5 
the column z. 
(6; HATE COL Cole 

-COL Deletes current column in MatrixWriter 8-8 
application. 
o (@)(MATRIX GOL 

coL- Deletes column z from array y. 14-6 


14-3 


z at a time. 


F PROE DONE 


COLE Specifies dependent and independent columns in H-4 
XDAT. 
C Must be typed in. 

COLCT Collects like terms in expression (v). 20-18 
C (SYMBOLIC) ELET 

COLCT Collects like terms in specified subexpression. 20-21 
o (4)(EQUATION) 4) RULES 

COLET 

COLCT Collects like terms in the expression in the current 20-28 
field. 
O (m) (SYMBOLIC) Manip expr... COLET 

COMB Returns number of combinations of y items taken 12-4 


G-8 Operation Index 


CONVERT 


COPY 


Name, Key, Description, Type, and Keys Page 
or Label 
CON Creates a constant array from a list of dimensions 14-2 
(y) and the constant number (7). 
Cc HATE HAKE COH 
COND Estimates the condition number of a square matrix 14-9 
Cc HATE i 
CONIC Selects CONIC plot type. 23-11 
C (DCECLODEFTYFE CONIC 
CONJ Returns complex conjugate of v. 12-13 
F CHEL CONS 
CONLIB Opens the Constants Library catalog. 25-13 
je GVEQUB)COLIE COMLI 
CONST Returns the value of the specified constant (z). 25-14 
F (4) (EQ Lib) COLI COS 
ANET 
CONT Continues halted program. 29-9 


c aD 


Converts one unit object (y) to dimensions of a 
different compatible unit (x). 


c GR) cony 


Copies the highlighted object to a new location. 


o (GEOR) cory 


CORR 


10-6 


5-9 


in DAT. 


c GEAD FIT. Col 


Calculates correlation coefficient of statistical data 


COS 


Cosine of an angle (x). 


A 


COSH 


Hyperbolic cosine of an angle (x). 


A 


12-3 


COV 


Calculates covariance of statistical data in X DAT. 


CR 


Causes printer to do carriage return/line feed. 


c amr 


Operation Index G-9 


LJ 


Name, Key, Description, Type, and Keys Page 
or Label 
CRDIR Creates a directory named r. H-4 
C  (4)QIEMORY) È 3 
CROSS Cross product of two vectors (y X x). 13-4 
C MTH) Ei ‘ 
CST Returns contents of CST variable. 30-1 
C  (4)(@ODES) HENN CST 
CSWP Swaps column y with column z of a matrix (z). 14-6 
C : 
CYLIN Selects cylindrical vector mode 13-2 
C 
C—PX Converts user-unit coordinates (x) to pixel 9-9 
coordinates. 
c PICT CPx 
CR Separates a complex number (x) into two real 12-14 
numbers. 
MTH CMP OCSR 
C TERE Dak 
-D Distribute left. 20-24 
o (4)(EQUATION)(@) RULES +p 
œ -D Executes = = until no change in 20-26 
subexpression. 
(EQUATION) A RULES #D 
0 QATOR E) «0 | 
D— Distribute right. 20-24 
o ()EQUATION)@RULES p+ 
œ- Executes = Et- until no change in 20-26 
subexpression. 
o  ()(EQUATION) (4) FU 
DARCY Calculates the Darcy friction factor for a fluid flow H-4 
as a function of the relative roughness of the pipe 
(y) and the Reynolds number (x) of the flow. 
F (@)@QUB)UTILS DARCY 
= 
EDAT Returns the contents of EDAT reserve variable to 21-1 


the stack. 


C QE i 


G-10 Operation Index 


Name, Key, Description, Type, and Keys Page 
or Label 


DATE Returns system date. 16-2 


c @\G@M pate 


DATE+ Adds or subtracts a number of days (x) from a 16-2 
date aa 


—DATE Sets system date to a eee date (x). H-5 


c GME nT 


DBUG Halts patie ale ) execution before first object. 29-8 


DDAYS Returns number of days between date; (y) and 16-2 
datez (z). 


C OTM RDE: 


DEC Sets decimal base. 15-1 
C (MTH) BASE DEC 
DECR Decrements value of a variable (x) by 1. H-5 
C ((DMEMORY)ARITH DECR 
DEFINE Creates variable or user-defined function from 5-13 
equation (x). 


c @ 11-7 
—DEF Expands trigonometric and hyperbolic functions in 20-25 
terms of EXP and LN. 


QAMAL +1 


DEG Sets Degrees mode. 4-4 
C (4)(MODES) ANGL 


DEL Erases area whose opposite corners are defined by 9-4 
mark and cursor. 


(4) (PICTURE) (DEL) 


o QER DEL 
+DEL Deletes all characters from cursor to start of word. 2-12 
o EDD +e 
(p>) —DEL Deletes all characters from cursor to start of line. 2-12 


Operation Index G-11 


DET 


DETACH 


c (QCA DEPTH 


Finds the determinant of a square matrix (x). 


Cc HATE HOREN DET 
Detaches specified library (x) from current 
directory. 


c QUM ETAC 


Name, Key, Description, Type, and Keys Page 
or Label 
DEL— [Dáse all characters from cursor to start of next 2-12 
word. 
Gor) ters 
O ... EDIF DEL> 
(>) DEL— Deletes all characters from cursor to end of line. 2-12 
QED vets 
o ... EDIT (@) BEL 
DELALARM | Deletes alarm (x) from system alarm list. H-5 
Cc (4) (TIME) ALEM GELAL 
DELAY Sets delay time (x seconds) between printing lines. 27-4 
C CT PRIHT PRTPA DELAY 
DELKEYS Clears specified user-key assignment for one or 30-6 
more keys (x). 
C (4)(MODES) KEYS DELE 
DEPND Specifies name (x) of dependent plot variable. H-5 
C (CELOT) FFARR DEFH 
DEPTH Returns number of objects on stack. 3-11 


14-9 


28-8 


—=DIAG 


DIAG— 


Returns the major diagonal vector of a matrix (x). 


Cc HATE (NXT)407AG 


14-5 


Creates a matrix from a vector of diagonal 
elements (y) and a list of dimensions (z). 


c HATE (NXT)E 


14-3 


DIFFEQ 


Selects the differential equation plot type. 


c @\@LONFTYFE DIFFE 


23-11 


DINV 


Double invert. 


o ()(EQUATION)(@) RULES DIHS 


20-21 


DISP 


Displays an object (y) in the rth display line. 


c GROG out pre 


G-12 Operation Index 


Name, Key, Description, Type, and Keys Page 


or Label 
DNEG [Double negate. 20-21 
o (4)(EQUATION)(@) RULES DHEG 
DO Begins indefinite loop. 29-14 
Cc ERCH DO DO 
po Types DO UNTIL END. 29-14 
(0) EECH @D bo 
DOERR Aborts program execution and displays specified H-6 


message (7z). 
Cc ERROR DOERR 


DOLIST Executes a program or command (2) on a specified 17-4 
number of lists (y) that are on the stack. 


Cc LIST PROC DOLIS 


DOSUBS Executes a program or command (2) on a specified 17-5 
number of elements at a time (y) within a list (z). 


c LIST PROG DOSUE 
DOT Dot product (y-x) of two vectors. 13-4 
C ECTE BOT 
DOT+ Turns on pixels as cursor moves. 9-3 
o (@)(PICTURE) ELIT GoT+ 
DOT- Turns off pixels as cursor moves. 9-3 
o (#)(PICTURE) ELIT OT- 
DRAW Plots equation without axes. 
c (ELOT) DRA 
DRAW Plots function as specified in current input form. 22-1 
O [plot input form] PERH 
DRAX Draws axes. 

|C G)@LOT) GRAS 


DROP Drops object (x) in level 1; moves all remaining 3-5 
objects down one level. 


c QD 


DROPN | Drops g objects from stack. 3-11 


c ORD EN 


Operation Index G-13 


Name, Key, 
or Label 


Description, Type, and Keys 


Page 


DRPN 


Drops all objects from stack at and below the 
current stack pointer. 


0 PERC) EXD e 


3-8 


DROP2 


Drops first two objects {y and z) from stack. 


c GER) Gx) oe 


DTAG 


Removes all tags from object (x). 


c TERE TAG 


DUP 


Duplicates object (x). 


C (ENTER } (when no command line) or 
(4)(STACK) (NXT) EUF 


DUPN 


Duplicates x objects on stack. 


C  (4)GTACK) (NXT) CUFH 


DUPN 


Duplicates all objects on stack from current stack 
pointer through level 1. 


o (@)GINCK) GX) DUF 
Duplicates objects in level 1 and level 2. 

c GREW ED pure 
Degrees-to-radians conversion. 

F REAL Dak 


Returns the symbolic constant e (or 
2.71828182846 depending on flag —2). 


F @@e 
CONSE 


3-8 


3-11 


12-7 


11-4 


ECHO 


Copies object in current stack level to command 
line 


o (@)\GIEK) Ecm 


EDIT 


Copies selected object into command line and 
selects EDIT menu. 


O [input form] ERIT 


EDIT 


Copies subexpression into command line and 
selects EDIT menu. 


o (4)(EQUATION) (4) EL 


7-11 


EDIT 


Edits current matrix cell. 


o GTN EDIT 


G-14 Operation Index 


Name, Key, Description, Type, and Keys Page 
or Label 
BEX Types E or moves cursor to existing exponent in 2-2 
command line. 
o 
EGV Computes the right eigenvectors and the 14-21 
eigenvalues for a square matrix (zx). 
C (MTH) HATE (NXT) EGY 
EGVL Computes the eigenvalues of a square matrix (z). 14-20 
ELSE Begins false clause. 29-10 
cS) ERD ER 
END Ends program structures. 29-10 
PRG) BECH DF EHE 
BRCH CASE END 
(PRG) BRCH DO EMD 
(PRG) BECH WHILE EMD 
|c EROJN (NXTJERROQR TFERRE EMD 
ENDSUB The frame index counter for DOSUBS. ins | 
C LIST: PROC: EHDS 
ENG Sets display mode to Engineering, displaying x + 1 4-2 
significant digits. 
© MODES) FMT ENG 
EQ Returns the contents of the reserved variable, FQ. 22-12 
OD 
C (ELOT ER 
EQ— Separates equation (x) into left and right sides. H-6 
c TEFE 
EQNLIB Starts the Equation Library. 
c @\GQUB)ESLIBE 
ERASE Erases a 22-1 
as PICTURE) c CLEAR) 
c @) 


Operation Index G-15 


EXPFIT 


Name, Key, Description, Type, and Keys Page 
or Label 
ERASE Erases PICT. 22-1 
o MEDE 
ERRM Returns last error message. H-6 
c ERROR EREN 
ERRN Returns last error number. H-7 
c ERROR EREH 
ERRO Clears last error number. 
C ER 
EVAL Evaluates object (x). 7-13 
c 
EXIT Exits EquationWriter options environment. 20-20 
o (4)(EQUATION) (4) EXIT 
EXP Constant e raised to power of object (x). 12-2 | 
A O@ 
EXPAN Expands algebraic object (x). 20-18 


C  (4)(GYMBOLIC) EFA 
EXPND Expands the algebraic object in the current field. 20-28 


O (SYMBOLIC) Manip expr... EXFH 
Sets curve-fitting model to exponential. 


MHODL ERPEI 


c GIT) EFRR 
EXPM 12-3 


Natural exponential minus 1 (e* — 1). 


A HYP ESPR 


EXPR Highlights subexpression for which specified object 
is top level function. 
o (4)EQUATION) (4) 20-19 
EXTR Moves graphics cursor to nearest extremum, 22-11 
displays coordinates, and returns them to stack. 
O (4)(@ICTURE) FCH EKTE 
EYEPT Specifies the x (z), y (y), and z (x) coordinate of H-7 


the eye-point in a perspective plot. 


C ELDER) t VFAR 
ETEFT 


G-16 Operation Index 


Name, Key, Description, Type, and Keys Page 


E^ Replace power-product with power-of-power. 20-25 
o ()(EQUATION) AR: EE 

E() Replace power-of-power with power-product. 20-25 
o (4)(EQUATION)@)JRULES Exo 

FOA Calculates the fraction of total black-body H-7 


emissive power at a given temperature (x) between 
wavelengths 0 to \ (y). 


F (4)EQUBJUTILE FOS 


FACT Finds the factorial of x. Same as !. H-7 
C Must be typed in. 
FANNING Calculates the Fanning friction factor for a fluid H-8 


flow as a function of the relative roughness of the 
pipe (y) and the Reynolds number (x) of the flow. 


F (4)@QUIB) UTILS FANNI 


FC? Tests if specified flag (x) is clear. 4-8 
TEST PERS 
C (4)(MODES) FLAG FEF 


B FC?C Tests if specified flag (x) is clear, then clears it. 4-8 
TEST FETE 
C (MODES) FLAG FETC 
FFT Computes the Discrete Fourier Transform of an 13-8 
array (x). 
C FEET FET | 
FINDALARM |Returns first alarm due after specified time (7). H-8 


FINISH Terminates Kermit server mode. 27-10 


FIX Selects Fix display mode to z decimal places. 4-2 
FLOOR Returns the next integer less than z. 12-9 


FM, Selects comma as the decimal place marker. 4-10 


Operation Index G-17 


Name, Key, 
or Label 


Description, Type, and Keys 


Page 


FOR 


Begins a definite loop with beginning (y) and 
ending (x) loop-counter values. 


29-13 


(4) FOR 


Types FOR NEXT. 


O 


29-13 


(>) FOR 


Types FOR STEP. 


O (RG) 


29-13 


FP 


Returns fractional part of a number (x). 


12-9 


FREE 


Frees the previously merged RAM in port 1 and 
moves a list of objects (x) from port 0 to port 1. 


c OQUE 


28-16 


FREEZE 


Freezes a display area (x) until a key is pressed. 


c GUT FREES 


FS? 


Tests if specified flag (x) is set. 
TEST 
C  (4)(MODES) FLAG FS? 


FS?C 


Tests if specified flag (x) is set, then clears it. 
TEST ; 
C (4)(MODES) FLAG FAFE 


H-8 


FUNCTION 


Selects FUNCTION plot type. 


c (MELOT) ETYFE FUNC 


23-1 


FV 


Sets the future value amount for the amortization 


solver. 


18-16 


F(X) 


Displays value of function at v-value specified by 
cursor. Returns function value to stack. 


o PICTURE) Fen GRD + 


22-11 


F? 


Plots first derivative of function, replots function, 
and adds derivative to EQ. 


o QCN FeN 


NXT por 


22-11 


GET 


Gets element in specified position (x) from array 
or list (y). 
C Lisio SE 


G-18 Operation Index 


Name, Key, 
or Label 


Description, Type, and Keys 


GETI 


Gets element in specified position (x) from array 
or list (y) and increments index. 


C (PRG) LIST ELEM 


GOR 


Superimposes one graphics object (rz) onto another 
(z) at specified coordinates (y), using a logical OR 
to determine the state of the pixels. 


C (PRG) GEODE GOR 


GO| 


Sets top-to-bottom entry mode. 


o GA) cos 


8-8 


GO— 


Sets left-to-right entry mode. 


o GRIN cos 


8-8 


GRAD 


Selects Grads angle mode. 


C (MODES) AHEL GRAD Ji 


4-4 


GRAPH 


GRIDMAP 


—GROB 


GXOR 


Enters Graphics environment. This is for 

compatibility only. 

C Must be typed in. 

Selects the GRIDMAP plot type. 

Cc (ELOT Sho PTYRE 
BEELD 

Converts object (y) into graphics object of a 

specified size (x). 

Cc ROE 

Superimposes one graphics object (x) onto another 


(z) at the specified location (y), using the logical 
XOR to determine the state of the pixels. 


C ROE 


SGRG 


23-34 


9-9 


9-9 


xH 


Multiplies the vertical plot scale by a factor (2). 


c QCD FAR $H 


HALT 


Halts program execution. 


c RUN 


29-9 


HEAD 


Gets the first element from a list (7). 


c IST: ELEN HEAL 


Operation Index G-19 


Name, Key, Description, Type, and Keys Page 


or Label 
HEX Sets hexadecimal base. 15-1 
C BREE HES 
HISTOGRAM | Selects HISTOGRAM plot type. 23-18 
HISTO 


HISTPLOT Draws histogram of data in X DAT. 


c GRAD PLOT HISTE 
S 


HMS+ Adds two times (y and x) in HMS format. 12-7 
cC (€Q) CME) (NXT) HNS+ 16-4 
HMS— Subtracts one time (x) from another (y) in HMS 12-7 
format. 
cC (4)(IME) (NXT) HHz- 16-4 
HMS— Converts a time (x)from HMS to decimal format. 12-7 
C (QCME) (NXT) HME 16-3 
—HMS Converts a time (x) from decimal to HMS format. 12-7 
C  (4)(EIME) (NXT) FHNS 16-3 
HOME Makes the HOME directory the current directory. 5-12 
c (PEME) 
HZIN Zooms in horizontally. 22-8 
O (4)(@PICTURE) 200 HZIH 
HZOUTN Zooms out horizontally. 22-8 
Oo (4)(PICTURE) 200 HEQUT 
i Returns the symbolic constant i (,/—1 or (0,1)). 11-4 
F(a) (Jl or (ITH) (NXT) CONS I 
IDN Creates square identity matrix of specified size (x). 14-2 
Cc NA NPE IDH 
IF Begins test clause. 29-10 
Cc BEECH IE IF 
DEF Types IF THEN END. 29-10 
(0) BECH @ IF 
(@)IF Types IF THEN ELSE END. 29-10 


O BECH (@) IF 


G-20 Operation Index 


Name, Key, Description, Type, and Keys Page 


or Label 
IFERR Begins test clause. 29-15 
Cc (PRG) (NXT) ERROR IFERE IFE 
(4)IFERR =| Types IFERR THEN END. 29-15 
O (PRG) (NXT) ERROE (Q)IFERR l 
(>) IFERR Types IFERR THEN ELSE END. 29-15 
O ERROR ()IF 
IFFT Computes the Inverse Discrete Fourier Transform 13-8 


of an array (r). 


C (MTH)(NXT) FFT TFET 
IFT Evaluates an object (x) if a test value (y) is a H-9 
non-zero real number. 


c BECH IET 


IFTE Evaluates one object (y) if a test value (z) is a H-9 
non-zero real number or another object (x) if the 
test value is zero. 


F ERCH TETE 
IM Returns imaginary part of complex number or 12-14 
array (x). 


F CHELO CIM 
INCR > i i ) H-9 


Increments value of specified variable (x). - 


cC (4)(MEMORY)JARITH THCE 


INDEP Specifies independent variable (x) in a plot. H-10 
C (*)@LOT) FFARR IHDEF 
INFO Displays information about reserved variables. 27-15 


o COD GD Fe 
DEON PPAR GEN GD 


mon 


rhea 


EPONE STAT IFAR 
THEO 
QEA = 


(Go) FOF 
QUO PRINT 


Operation Index G-21 


Displays information about the most recent 
computation by the root-finder. 


(@)GOLVE) SOLVE THEO 


Toggles the automatic display of parameter 
variable information. 


o (MODES) MISC (NXT) INFO? 


Displays a user-defined input form. 
C IH THFOR 
Stores the values of a differential equation solution 


as the new initial values to prepare for another 
iteration. 


O  (G>)(SOLVE) solve diff eq... IHIT# 


Suspends program execution, displays message (y) 
above the stack, and prompts (z) for data input to 


INFORM 


INPUT 
the command line. 
C IH IHPUT 


INS Switches between insert /replace character. 2-12 
o (4)@pIT) IHs 
NV 


I 


Returns the contents of the JOPAR reserved 
variable. 


Moves graphics cursor to closest intersection in 
two-function plot, displays intersection 
coordinates, and returns coordinates to stack. 


o (@)(PICTURE) FCH ISECT 
Isolates variable (z) on one side of an equation (y). 
c  (4)GYMBOLIC) 1S0L 


Clears all levels above current level. 


(GCE) GET) KEEF 


G-22 Operation Index 


LASTARG 


LCD 


—LCD 


C Must be keyed in. 


Returns previous argument(s) to stack. 
C ERROR LASTA 
Returns graphics object to stack representing stack 
display. 

C GEDE Libs 

Displays specified graphics object (x) in stack 
display. 

C PRG 


PEPES 


GRGE 


Name, Key, Description, Type, and Keys Page 
or Label 
KERRM Returns text of most recently-received KERMIT H-10 
error packet. 
°c Om ERR 
KEY Returns number indicating last key pressed. H-10 
c TRS ORES 
KGET Gets a list of objects (x) from another device. 27-10 
c (D00) EVE EGET 
wo Transfer... EBET 
KILL Aborts all suspended programs. 29-9 
c RUHO EILL 
LABEL Labels axes with variable names and ranges. 
C (4)(PLOT) (NXT) LABEL 
LABEL Labels axes with variable names and ranges. 24-1 
o (@)@ICTURE) EDIT (WXT)LABEL 
LAST Returns previous argument(s) to stack. 


LEVEL 


Enters current level number into level 1. 


LIBEVAL 


Evaluates a system library object (x). Use only as 


specified by HP applications. 
C Must be typed in. 


LIBS 


Lists all libraries attached to current directory. 


LINE 


Draws line between two coordinates (x and y). 


C PICI 


LIHE 


9-8 


Operation Index G-23 


TFE LIST 
C LIST e181 


Combines objects from level 1 to current level into 
a list. 


o MEWT 


—LIST 


c LIST 2LIST 


Name, Key, Description, Type, and Keys Page 
or Label 
LINE Draws line from mark to cursor. 9-3 
O (4)(@PICTURE) EDIT LIHE 
ELINE Returns best-fit line for data in X DAT according H-11 
to selected statistical model. 
c (DSTA) FIT ELIHE 
LINFIT Sets curve-fitting model to linear. 
c (4)GTAT) FAR MOEL LIHFI 
LININ Tests whether an expression (z) is a linear H-11 
function of a variable (y). 
F TEST (|)(REV)LINIH 
LIST— Disassembles a list (x) into its constituent | Ha 
elements. 
C Must be typed in. 
—LIST Combines x objects (y, z, etc.) into a list. 17-1 


3-8 


ZLIST Adds together all of the elements in a list (zx). 


17-8 


A Oa 


TILIST Multiplies together all of the elements in a list (x). 17-8 
Cc Ebed Le 

ALIST Finds the set of first differences of a finite sequence 17-8 
in a list (x), 
C LEST: akor 

LN Natural (base e) logarithm of z. 12-2 

‘OW 

LNP1 Natural logarithm of (x + 1). 12-3 
A HTE LH 

LOG Common (base 10) logarithm of z. 12-2 


G-24 Operation Index 


Name, Key, Description, Type, and Keys Page 
or Label 
LOGFIT Set curve-fitting model to logarithmic. 
cC (DOTAT) FFARR PL LOGFI 
LQ Returns the LQ factorization of a matrix (z). 14-21 
c LE 
LR Calculates linear regression. H-12 
LSQ Computes the minimum norm least squares 14-15 
solution to an under- or over-determined system of 
linear equations AX = B, where A (y) is the 
matrix of coefficients and B (r) is the vector of 
right-hand constants. 
(4)(SOLVE) SYS LSE 
C HATE Lee 
LU Returns the Crout LU factorization of a square 14-21 
matrix (x). 
C HATE PAGE gold 
L* Replace log-of-power with product-of-log. 20-25 
0 EQUATION) @)RULES Le 
LO Replace product-of-log with log-of-power. 20-25 
O (4) (EQUATION) =) RULES Lad 
—M Merge-factors-left. 20-24 
o ()(EQUATION)@)RULES +h 
œ —M Executes) +P} until no change in 20-26 
subexpression. 
0 QETA: em 
M— Merge-factors-right. 20-24 
0 EASE ; 
M> Executes Mite until no change in 20-26 
subexpression. 
o (MEUTON) (<) F pa 
MANT Mantissa (decimal part) of number (v). 12-10 


Operation Index G-25 


HAS 


F MTH) REAL 


maximum machine-representable real number 
(9.99999999999E499). 


F CONS MARE 


Name, Key, Description, Type, and Keys Page 
or Label 
MARK Sets mark at cursor position. 9-3 
(#4) (PICTURE) (x) 
O (4)(PICTURE) ERIT HARE 

MATCH Accesses the pattern matching functions within 20-28 
the symbolic input form. 

O (P)(SYMBOLIC) Manip expr... Te 

TMATCH Rewrites an expression (y) using a H-12 
pattern-matching list (r) to replace particular 
subexpressions, searching the most deeply nested 
subexpressions first. 

C  (4)GYMBOLIC) (NXT) * 

JMATCH Rewrites an expression (y) using a H-12 
pattern-matching list (x) to replace particular 
subexpressions, searching the top-level expressions 
first. 

c (#4)(SYMBOLIC LAAT 
MAX Maximum of two real numbers (x and y). 12-10 


MAXR Returns the symbolic constant MAXR, the 11-4 


Displays the specified built-in or custom menu (v). 


—_ 
MAX Maximum column values in statistics matrix in H-12 
XDAT. 
C (4)GTAT) IVAR OHAR 
MCALC Declares the specified variable or list of variables H-13 
(x) to be “calculated-only.” Used only in 
conjunction with MROOT. 
c OEH Hes 
MEAN Calculates mean of statistical data in X DAT. H-13 
MEM Bytes of available memory. H-13 
C (MEMORY) NEN 
MENU 30-1 


G-26 Operation Index 


Name, Key, 
or Label 


Description, Type, and Keys 


Page 


MENU 


Toggles the softkey menu on and off. 


QOO 


22-6 


MERGE] 


Merges plug-in RAM memory in port 1 with main 
memory. 


28-16 


MIN 


Minimum of two real numbers (y and 2). 


F MTH) RERI 


12-10 


MINEHUNT 


Starts the Minehunt game. 


C ()JEQLIB)JUTILE MI 


25-14 


MINIT 


Creates a new Mpar from EQ. 


c (JQ) NES ft 


MINR 


MIN= 


MITM 


ML 


Returns the symbolic constant MINR, the 
minimum. machine-representable real number 
(1.00000000000E —499). 


F (MTH COS MIE 


Finds minimum column values in statistics matrix 
in DAT. 


c ()GTAD ivAR MINE 


Customizes the solver menu, using a title string 
(y) and a list of variables (x). 


C QED NES° MIT 
Chooses multiple-line or single-line display for 
multiline results. 


o (4)(MODES) FMT) ML 


H-13 


4-10 


MOD 


Returns the modulus remainder of y divided by v. 


F REAL NOD 


12-10 


MOVE 


Moves the selected variable(s) to a new directory. 


O (@)(MEMORY) HOVE 


MSGBOX 


Creates a user-defined message box from a string 
(x). 
C OUT MSCE 


Operation Index G-27 


Name, Key, Description, Type, and Keys 
or Label 


MROOT 
MSOLVR 


MUSER 
NDIST 


NEG Negates z. 
A CA) or (MTH) CMPL 
NEW 


Solves a set of equations for the specified variable 
(£) starting with only user-defined values (see 
MUSER and MCALC). 


c Om i 


Begins the solver using the current contents of the 
reserved variable EQ. 


c OD nes 


Makes the specified variable or list of variables (z) 
user-defined. Used only in conjunction with 
MROOT. 


Cc (ELB) MNES MUSE 
Returns the normal probability distribution (bell 


curve) at z based on the variance (y) and mean 
(z) of the normal distribution. 


c FEDE (NXT)HDIST 


penn 


Heul 


Returns number of rows in Y DAT. 


C (4 )(STAT) GUNS HZ 


HEG 


Creates a new, named object. 
| eaen e |e | 
NEW Creates a new alarm. 
Ls (0) (>) (IME) Browse alarms... HEL | 
Converts object (x) taken from a composite object 
or variable into a new, independent object. 
c (@)(MEMORY) NENO 


Ends a definite-loop structure. 
ERCH START HET 
c BROH FOR HEST 


Displays but does not execute next one or two 
objects in suspended program. 


o RUNS RET 


G-28 Operation Index 


Name, Key, 
or Label 


Description, Type, and Keys 


NOT 


Returns the binary or logical NOT of z. 
aT HOT 
F BASE LOGIC HOT 


H-15 
15-4 


NOVAL 


Place holder for reset and initial values in 
user-defined dialog boxes. NOVAL is returned to 
the stack when a field is empty. 


c IH NOVA 


NSUB 


Provides a way to access the current frame number 
during an iteration of a program or command 
applied using DOSUBS. 


C LIST FROT HSUE 


17-5 


NUM 


NUMX 


NUMY 


Returns character code of first character in string 
(z). 
Cc TYRE HUM 


Sets the number of x-steps for each y-step in 3D 
perspective plots. 


o QOD sp vrAR 
HUME 


Sets the number of y-steps across the view-volume 
in 3D perspective plots. 


Cc QODMA a SPAR 
HUM 


—NUM Converts a symbolic object (x) to a number, as far 11-5 
as possible. 
c ex 
NXEQ Changes the current equation by rotating the 22-11 
elements in the list in EQ. 
O (4)(@ICTURE) FEH HSER 
OBJ— Separates a composite object (x) into its H-16 
components. 
PRG E- Ope 
LIST -0 17-7 
c  (4)(CHARS) (NXT) + 
OCT Sets octal base. 15-1 
C BASES CHET 
OFF Turns calculator off. 
c RUM (NXT 


Operation Index G-29 


Name, Key, 
or Label 


Description, Type, and Keys 


Page 


OK 


Accepts the values of all the fields as they are 
currently displayed or performs the main action of 
the input form. 


[input form] (ENTER 


O [input form] BE 


OLDPRT 


Remaps HP 48haracter set to match HP 82240A 
Infrared Printer. 


c (QO PRINT PETEA OL 


OPENIO 


Opens serial port. 


c (QUO NXT) SERIA OFEHI 


27-3 


OPTS 


Selects plot options. 


O œ) PLOT }all plot types UF 


22-2 


OR 


ORDER 


Logical OR of two expressions (x and y) that 
evaluate to 1 or 0 or binary OR combining two 
integers (x and y) or two strings (x and y). 


BASE (NXT)LOGIC 


PRG ST NXT OR 


GE 
F 


cC (A)MEMORY) GIF ORDER 


Rearranges VAR menu in order specified in list (x). 


15-4 


H-16 


c GENO) i 


OVER Duplicates the object in level 2 in level 1. 3-12 
C (4)GTACK) OVER 
EPAR Reserved variable that stores statistical regression 21-12 
data. 
a C (q)GTAT) ZPAR SFAR 
PARAMETRIC | Selects PARAMETRIC plot type. 23-7 
C (4)(PLOT) PTYPFE PARA 
PARITY Sets the specified parity value (zr). H-17 
C O FRR PRR DT 
PARSURFACE | Selects PARSURFACE plot type. 23-35 
0 OCD aD 
PARSL 
PATH Returns list containing path to current directory. H-17 


G-30 Operation Index 


Name, Key, 
or Label 


Description, Type, and Keys 


Page 


PCOEF 


Finds the coefficients of the polynomial with the 
specified array of roots (zr). 


C (4)GOLVE) FOLY FOOEF 


18-10 


PCONTOUR 


Selects the PCONTOUR plot type. 


PtH 


23-30 


PCOV 


Calculates the population covariance. 


c @CED FIT WT 


PDIM 


Replaces PICT with a blank PICT of specified 
dimensions (y) and (x). 


24-3 


PERM 


Returns the permutations of y items taken v at a 
time. 


F (MTH PROE PERM 


PEVAL 


PGDIR 


Evaluates a polynomial with a specified array of 
coefficients (y) at a given value (7). 


C (4)(SOLVE) FOLY FEVAL 


Purges specified directory (x) and all of its 
contents, 


C (4|)(MEMORY) GIF FOODIE 


Copies object in level x to level 1. 


c QCA rice 


Copies object in current level to level 1. 


o (@)GICK) PICK 


12-4 


18-11 


PICT Puts the name PICT on the stack. 9-8 
C EEGI PELOT 
PICT— Copies the current PICT as a graphic object and 22-6 
puts it on the stack. 
(#)(PICTURE) (STO) 
PICTURE Enters Graphics environment. 9-2 


o OT 


Operation index G-31 


Name, Key, Description, Type, and Keys Page 
or Label 
PINIT Initializes all ports containing RAM without 28-14 
erasing data. 
C  (@)(LIBRARY) (NXT) FIHIT 
PIXOFF Turns off specified pixel (x) in PICT. 9-8 
Cc PILE FPISOF 
PIXON | Turns on specified pixel (x) in PICT. 9-8 
c PICT FISOH 
PIX? Tests whether specified pixel (x) in PICT is on or 9-9 
off. 
c PICT NID FIX? 
PKT Used to send a command string (y) of a given type 27-13 


(x) to a Kermit server. 

Cc o) SEVER PET 
Sets upper-right plot coordinates (x). H-17 
C Must be typed in. 
PMIN Sets lower-left plot coordinates (x). 
C 


PMT The payment variable in the amortization solver. 


Must be typed in. 


cC (4)GOLVE) Ten SOLVER FHT | 
POLAR Selects POLAR plot type. 23-4 
C (4)@LOTJFPTYFE FOLAR 


Returns the position of substring (x) in string (y) 17-6 
or object (x) in list (y). 


C brer ELEM: FUS 


PRED Using the current regression model, calculates the 21-10 
predicted value of one variable given the value of 
the other. 
o (@)STAT)Fit Data... FEED PRED 

PREDV Returns predicted value for dependent variable, H-18 


given value of independent variable (zx). 
C Must be typed in. 


PREDX Returns predicted value for independent variable, H-18 
given value of dependent variable (x). 


c (@)GTAT) FIT FREDS 


G-32 Operation Index 


Name, Key, Description, Type, and Keys Page 
or Label 
PREDY Returns predicted value for dependent variable, H-18 
given value of independent variable (r). 
c (4)GTAT) FIT 
PRINT Prints an object. 27-4 
o (@)GO) Print... PRINT 
PRLCD Prints current ae eam 
oro a Print aispa 
Simultaneously press and 
PROMPT Displays prompt string (x) in status area and halts H-19 
program execution. 
PROOT Computes all roots of a polynomial with the 18-10 
specified array of coefficients (x). 
C (4)GOLVE) POLY: PROOT 
PRST Prints all objects on stack. 27-6 
C )\MO)PRINT PRET 
PRSTC Prints all objects on stack in compact format. 
cC (QOO FRIHT FESTE 
PRTPAR Reserved variable that contains the current printer 27-3 
settings. 
C o) (VO)EFRIHT FRTPA PETEA 
PRVAR Prints name and contents of one or more variables 27-6 
(x), including port names. 
C (OO FRET Fi 
PRI Prints object in level 1. 27-6 
o O FF 
PSDEV Calculates population standard deviation. H-19 
c (4)(STAT) IVRE WXT)F 
PURGE Purges one or more specified variables (x). 5-12 


c Qe 


Operation Index G-33 


Name, Key, Description, Type, and Keys Page 


or Label 
PURG Purges selected objects or alarms. 
(>) (MEMORY) (NXT) FURS 5-10 
O CME) Browse Alarms... F : 26-5 
Purges all variables for current title. 25-5 
o MELB)... VARS (NXT) 
PUT Replaces element in specified position (y) in array 14-7 


or list (z) with another element (x). 
Cc ETEF 


PUTI Replaces element in specified position (y) in array 17-6 
or list (z) with another element (x) and 


increments index. 


C ErST PUTT 
PV Present value of a loan in the amortization solver. 18-16 
C (DOLE): TSM SOLVE 


PVAR Calculates population variance. H-19 

c ETT IVA ENAR 
PVARS Returns list of current backup objects and libraries 28-4 
within a port (2). 


c GERARD) Pvars 


PVIEW Displays PICT with specified pixel coordinates (x) H-19 
as the upper-left corner. 


Cc QUT PATER 
PWRFIT Set curve-fitting model to Power. 
c (#)(STAT) EPRE NODL FI 


PYR Payments per year in the amortization solver. 18-16 


PX-—C Converts pixel coordinates (x) to user-unit 9-9 
coordinates. 


C PRG) EEET (NXT 


—Q Converts number (zx) to fractional equivalent. 16-5 


C (4)GYMBOLIC)(AXT) #8 


QR Computes the QR factorization of a matrix (2). 14-21 


c 


G-34 Operation Index 


random-number seed. 

RARE 
Computes the rank of a rectangular matrix (x). 
C HATE HORM RAE 


Creates a matrix with random elements from a list 
of specified dimensions (7). 


c MATE MAKE RAHN 


Name, Key, Description, Type, and Keys Page 
or Label 
QUAD Solves a first or second order equation (y) for a 20-15 
given variable (x). 
C (4)GYMBOLIC) GUAR 
QUOTE Returns argument expression (1) unevaluated. H-20 
F  ()(SYMBOLIC) NXP NXT) Suar 
—Qr Calculates and compares quotients of number (zx) 16-6 
and number/7, returning the one with the smaller 
denominator. 
C (4)GYMBOLIC) (NXT) #09 
RAD Sets Radians mode. 4-4 
C (%)(@ODES) AHGL EAD 
(>) 
RAND Returns random number, and updates the 12-4 


14-3 


stack. 


c OED 


RATIO Prefix form of / used internally by EquationWriter H-20 
application. 
F Must be typed in. 
RCEQ Returns equation(s) in EQ to level 1. H-20 
c GoD sb ER 
RCI Multiples the specified row (x) of an array (z) by a 14-19 
factor (y). 
c HATE ROM RET 
RCIJ Multiples a specified row (y) of an array (t) by a 14-19 
factor (z) and adds the result to another row (z}. 
c HATE ROW ROL 
RCL Recalls object stored in specified variable (x) to 7-11 


Operation Index G-35 


RDM 


RDZ 


Name, Key, Description, Type, and Keys Page 
or Label 
RCL Recalls the selected object to the stack. 5-9 
O (@)(MEMORY) NXT) FEL 
RCLALARM | Recalls specified alarm (x) from system alarm list. H-21 
c (ME) RCLAL 
RCLF Returns binary integer representing states of 24-7 
system flags. 
CODES) FLAG 
RCLKEYS Returns list of current user-key assignments. 30-7 
RCLMENU Returns menu number of current menu. H-21 
RCLE Recalls current statistical matrix in Y DAT. H-21 


SORT 


c (GAT) CATA ICAT 


RCWS Recalls binary integer wordsize. 15-2 


C (MTH) BASE ROMS 
Redimensions the elements of an array (y) 
according to the specified dimensions (x). 


(6; HATE MARE ROM 


Sets random number seed. 


c (MTH EROE REE 


RE 


Returns real part of complex number or array (7). 


r UDAD: 


RE 


en: Lise os 


14-10 


RECN 


Waits for specified data (x) from remote source 
running Kermit software. 


c CNX) F! 


H-21 


RECT 


Sets Rectangular mode. 


13-2 


RECV 


Waits for sender-specified data from remote source 
running Kermit software. 


c O rc 


G-36 Operation Index 


Name, Key, Description, Type, and Keys Page 
or Label 
RECV Prepares the HP 48 to receive data. 27-11 
oO PG) Transfer... REMY 
REPEAT Begins loop clause if the result of the test-clause 29-14 
(z) is non-zero; otherwise execution resumes 
following the corresponding END. 
Cc 
REPL Replaces portion of object (z) with another like 
object (x) starting at the specified position (y). 
: 17-7 
Cc H-22 
REPL Replaces portion of PICT with level-1 graphics 9-4 
object. 
o (4)(PICTURE) EDIT 
PETI 
fr S 
REPL Replaces one symbolic pattern with another in an 7-12 
expression. 
o QCA REFL 
RES Sets spacing (x) between plotted points. H-22 | 
c (CELOT) FFARR RES 
RESET Resets current field value (or, at user’s discretion, 6-6 


all field values in current input form) to its default 
setting. 


o @ELoT) RESET 


cc Senha ŘŮĖĖ— 


RESET Resets plotting parameters to their defaults. 22-14 
(4) Lor ab 
o (CELOT) FERR 
RESTORE Replaces HOME directory with the specified 28-6 
backup copy (2). 
c (4)(MEMORY) (NXT)! 
REVLIST Reverses the elements in a list (x). 17-6 


Cc 


Operation Index G-37 


Name, Key, Description, Type, and Keys Page 
or Label 
RKF Uses a list (z)—containing the name of the time H-22 
variable, the name of the solution variable, and the 
differential function—and the absolute error 
tolerance (y) to compute the solution of the initial 
value problem at a point (x) using the 
Runge-Kutta-Fehlberg (4,5) method. 
C (4)GOLVE)MIFFE REF 
RKFERR Uses a list (y)—containing the name of the time H-23 
variable, the name of the solution variable, and the 
differential function—and a possible step size (x) 
to compute the change in solution and an absolute 
error estimate for that step using the 
Runge-Kutta-Fehlberg (4,5) method. 
C  ()(SOLVE)DIFFE FEFE 
| 
RKFSTEP Uses a list (z)—containing the name of the time H-23 
variable, the name of the solution variable, and the 
differential function—and a possible step size (x) 
to compute the next solution step of the initial 
value problem using the Runge-Kutta-Fehlberg 
(4,5) method such that the specified absolute error 
tolerance (y) is satisfied. 
C (4)GOLVE)GIFFE REFS 
RL Rotates binary integer (x) left by one bit. 15-5 
C BASE BIT EL 
RLB Rotates binary integer (x) left by one byte. 15-5 
C BASE BYTE ELE 
RND Rounds numerical object (y) to the specified 12-10 
number (x) of decimal places or significant digits. 
F REAL RHD 
RNRM Calculates row norm of array (x). 14-8 
C HATE HORM RHI 
ROLL “Rolls up” z levels of the stack, so that level r+1 3-12 
moves to level 1. 
C (STACK) ROLL 
ROLL “Rolls up” stack so that pointer level moves to 3-8 


level 1, level 1 moves to level 2, and so forth. 


o EMA Rot 


G-38 Operation Index 


Name, Key, Description, Type, and Keys Page 
or Label 


ROLLD “Rolls down” v levels of the stack so that level 2 3-12 
(y) moves to level z. 


c QCA route 


ROLLD “Rolls down” stack, so that level 1 moves to 3-8 
pointer level, level 2 moves to level 1, and so forth. 


o (@)GINEK) ROLLY 


ROOT Solves for unknown variable (y) in equation (z), H-23 
beginning the search from an inital guess (x). 


c (4)(SOLVE) FOOT ROOT 


ROOT Moves graphics cursor to intersection of function 22-10 
plot and z-axis, displays value of root, returns 
value to stack. 


Oo (@)(PICTURE) FENH BOOT 


ROT Moves object in level 3 to level 1, moves up objects 3-12 
in levels 1 and 2. 


c OC Rot 


ROW + Expands an array (z) by inserting a row vector (y) 14-5 
at the specified row number (v). 


c HATE RON ROMs 


+ROW Inserts row of zeros at current row in Matrix 8-8 
Writer. 
o (MATRIX FROM 

ROW- Deletes the specified row (x) of an array (y). 14-6 
c HATE CRONO ROMS 

-ROW Deletes current row in Matrix Writer. 8-8 

JO (@MARK (NXT) -FAH 

—ROW Disassembles an array (x) into its component row 14-4 
vectors. 
(0) HATE ROM SROH 

ROW — Assembles a sequence of row vectors ( ... , z, y) 14-3 


into a matrix containing x rows. 


C MTH) HATE FOH ROMS 


RR Rotates binary integer (x) right by one bit. 15-5 


c BAS BIT RE 


Operation Index G-39 


or Label 


Name, Key, 


Description, Type, and Keys 


Page 


RRB 


Rotates binary integer (x) right by one n 


c ERSE EY 


15-5 


RREF 


Computes the reduced row echelon form of a 
rectangular matrix (x). 


c MATE EACTE 


14-20 


RRK 


Uses a list (z)—containing the name of the time 
variable, the name of the solution variable, the 
differential function and its first two derivatives— 
and the absolute error tolerance (y) to compute 
the solution of the initial value problem at a point 
(x) using the Rosenbrock and Runge-Kutta 
methods. 


C (4)GOWE)PIFFE FRE 


H-23 


RRKSTEP 


Uses a list ({)—containing the name of the time 
variable, the name of the solution variable, the 
differential function and its first two derivatives— 
the absolute error tolerance (z), a possible step 
size (y), and a value (x) indicating the solution 
method used in the previous step. Computes the 
next solution step of the initial value problem 
using a combination of Rosenbrock and 
Runge-Kutta methods. 


C (4)GOLVE)CIFFE FREES 


H-24 


RSBERR 


Uses a list (y)—containing the name of the time 
variable, the name of the solution variable, the 
differential function, and its first two derivatives— 
and a possible step size (x) to compute the change 
in solution and an absolute error estimate for that 
step using a combination of Rosenbrock and 
Runge-Kutta methods. 


C (4)(SOLVE)PIFFE ESEER 


H-24 


RSD 


Computes the residual z-yz of three arrays. 


c MATR 


14-17 


RSWP 


Swaps two specified rows (y and x) of an array (z). 


c (MTH 


R—=B 


Converts a positive real integer (x) to its binary 
integer equivalent. 


C MTH) BASE B+E 


G-40 Operation Index 


Name, Key, 
or Label 


Description, Type. and Keys 


- 
Page 


R-C 


Combines separate real (y) and imaginary (r) 
components into one complex number (or array). 


12-14 


R-—D 


Converts a angle measure (x) from radians to 
degrees. 


12-7 


SAME 


Tests two objects (y and x) for equality. 


H-24 


SBRK 


Sends serial break. 


c GOED si 


27-18 


SCALE 


SCATRPLOT 


SCATTER 


Sets horizontal (y) and vertical (x) scale of PLOT 
axes. 


c (4)(@LOT) FFAR (NXT) SCALE 


H-24 


Draws scatter plot of statistical data in X DAT. 


c (CAD FLOT SCATR 


SCAT T 


Selects SCATTER plot type. 23-20 


SCHUR 


Computes the Schur decomposition of a square 
matrix (7) 


C (MTH) MATE FACTAE SCHOR 


SCI 


—— 


Sets Scientific display mode with x decimal places. 


C  (4)(MODES) FH] 


SCLE 


Autoscales data in X DAT for scatter plot. 
Cc Must be typed in. 


SCONJ 


Conjugates contents of variable (<). 


SDEV 


T 
Calculates standard deviation for each of the 


columns in X DAT. 


c OD 


H-25 


SEND 


Sends a copy of a variable (x) to a Kermit device. 


£ OA SEHD 


Operation Index G-41 


us 


Name, Key, Description, Type, and Keys Page 
or Label 
SEND Sends the specified object(s) in the manner 27-10 
designated in the input form. 
O a20] [various] SEHE: 
SEQ Generates a sequence (a list) from an expression 17-7 
(v) involving a variable (t) whose value is 
incremented from z to y in steps of size r. 
C LIST PROG Z 
SERVER Puts HP 48nto Kermit Server mode. 
C (4)G/0) SERVE SERVE | 
SF Sets specified flag (x). 4-8 
F SF 
C (4)(MODES) FLAG SF 
SHADE Shades the area between the graph of a function 22-10 
and the x-axis or between two graphs, between the 
z-values defined by the mark and cursor. 
oO (+) PICTURE) FEH SHADE 
SHOW Reconstructs expression (y) to make explicit all 20-17 
references to a variable (zx). 
C  (4)GYMBOLIC) SHO 
SIDENS Calculates the intrinsic density of silicon as a H-25 
function of temperature (x). 
F (4)(EQ LIB) UTILS SIDEN 
SIGN Returns sign of a number (7). 12-10 
F REAL SIGH 
Returns unit vector of a complex number (2). 12-14 
F CHEL ZIGH 
SIMU Toggles between simultaneous and sequential 23-2 
plotting of multiple functions. 
o (DELT FLAG. SIMU 
SIN Sine of v. 12-2 
A 
SINH Hyperbolic sine of z. 12-3 
A HYP SIHH 
SINV Replaces contents of variable (x) with its inverse. H-25 
C  (4)(MEMORY) BEITH SHY 


G-42 Operation Index 


Name, Key, Description, Type, and Keys Page 
or Label 
SIZE Finds dimensions of list, array, string, algebraic 
object, or graphics object (x). 
PRG) LIST ELEM 17-6 
c GEDE z 9-10 
SIZE Displays the size of the selected object in bytes 5-11 
and the amount of available memory. 
o (@)(MEMORY) (NXT) 21 
«SKIP Moves cursor left to next logical break. 2-12 
O 
SKIP — Moves cursor right to next logical break. 2-12 
oO . BEER 5 : 
SL Shifts a binary integer (x) left by one bit. 15-5 
c BASE BIT. 8. 
SLB Shifts a binary integer (x) left by one byte. 15-5 
C BASE PETES CPER 
SLOPE Calculates and displays slope of function at cursor 22-10 
position, returns slope to stack. 
O (#)(PICTURE) FEH SLOPE 
SLOPEFIELD |Selects the SLOPEFIELD plot type. 23-25 
c QED ath ETIE 
SLOPE 
SNEG Negates contents of variable (x). H-26 
C (MEMORY) Fi | NXT) SHEG 
SNRM Computes the spectral norm of an array (x). 14-8 
C MTH) HATE F 
SOLVE Initiates the solving procedure for the current 18-1 
problem. 
Oo (>) GOLVE) [various] & 
SOLVEQN Sets up the solver with a built-in equation set— H-26 


designated by subject (z) and title (y)—and loads 
the accompanying diagram into PICT if specified 


(z). 
c ODE 


Operation Index 


G-43 


Name, Key, Description, Type, and Keys Page 
or Label 
SORT Sorts the elements in a list (x) in ascending order. 17-6 
C (MTH) LEST 
SPHERE Sets spherical coordinate mode. 13-2 
SQ Returns square of v. 12-1 
a owa 
SR Shifts a binary integer (x) right by one bit. 15-5 
c BASE BLT 
SRAD Computes the spectral radius of a square matrix 14-9 
Cc MATER HI 
SRB Shifts a binary integer (x) right by one byte. 15-5 
Cc BASE BYTE SRE 
SRECV Reads specified number of characters (x) from 27-18 
serial port. 
c To) SERIA SRECY 
SST Single-steps through suspended program. 29-8 
o RUM SST 
SST | Single-steps through suspended program and its 
subroutines. 
(PRG) (NXT) RUM GST 
START Begins definite loop. 29-12 
c ERCH: START START 
(4)START | Types START NEXT. 
(@)START | Types START STEP. 
O (PRG) EECH (@)STA 
STD Sets Standard display mode. 4-2 
o QUD FHT STD 
STEP Ends definite loop. 
ERCH 29-12 
(6; ERCH 5 STEP 29-13 


G-44 Operation Index 


Name, Key, Description, Type, and Keys Page 


or Label 

STEP Executes the next step in a step-wise 20-10 
differentiation. 

STEQ Stores equation (x) in EQ. 18-7 

ene) E 

c (DELT) Sb (4) Es 

STIME Sets serial transmit/receive timeout {x seconds). 27-18 
c COG 

(STK Selects Interactive Stack. 


GDH) +T T 
o (Œ MATRIX) (NXT) *ETE 8-8 


—STK Copies the currently highlighted element in the 8-8 
MatrixWriter to the stack. 


o GATE) GXD stk 


STK Copies the equation set to the stack. 25-4 
o ME ESTE 
STO Stores object (y) in variable (x). 5-11 
o 
STOALARM Stores alarm (x) in system alarm list. H-26 
C (4)(TIME) ALEN STOAL 


Eoo 
STOF Uses a binary integer (x) to set state of system 24-7 
flags or a list of two binary integers (x) to set state 
of system flags and user flags. 


C (ANMODES) FLAG STI 


STOKEYS Uses a list (x) to make multiple user-key 30-5 
assignments. 


C (4)(MODEs) E 


STO+ Adds number or other object to the contents of H-27 
specified variable. 


c OUM ae 


STO- Calculates difference between contents of specified H-27 
variable (y). and specified number or other object, 


STOE 


and stores result in specified variable. 


c MM Ar 


Eg 5 F E pee 


LEEI 


Operation Index G-45 


command) and applies it to every element of a list 


(v). 
C (PRG) LIST FEGE STREA 


Name, Key, Description, Type, and Keys Page 
or Label 
STOx Multiplies contents of specified variable by H-27 
specified number or other object. 
STO/ Calculates quotient of contents of specified H-27 
variable and specified number or other object, and 
stores result in specified variable. 
C (4)(MEMORY)ARITH STOS 
STOE Stores current statistics matrix (x) in X DAT. H-28 
c GETT ERTA (4) ZERAT 
STR— Evaluates a string (x) as if its text were entered 
from the command line. 
C Must be typed in. 
—-STR Converts an object (x) into a string. H-28 
Cc Oe a eee era 
STREAM Takes an object (x) (normally a program or 17-5 


o (EQUATION) (4) SHE 


G-46 Operation Index 


STS Displays a status line showing the current 6-5 
directory, the modes and flags that are set, and the 
current date and time. 
O [input form] DALE 875 
STWS Sets binary integer wordsize to x bits. 15-2 
C (MTH) BARSE STM 
SUB Extracts the portion of list, string, array, or 
graphics object (z) specified by start (y) and end 
(x) positions. 
[SLL SSB 17-7 
(4)(CHAR) SUE 
HATE MAKE SUE 
C CEOE SUE 9-10 
SUB Returns specified portion of PICT to stack. 9-4 
O (4)(PICTURE) EDIT 
SUE 
SUB Returns specified subexpression to stack. 20-20 


Name, Key, Description, Type, and Keys Page 
or Label 


SVD Compute the singular value decomposition of a 14-22 
rectangular matrix (x). 


c HATE FACTR 5 


SVL Computes the singular values of a rectangular 14-22 
matrix (x). 


SWAP Exchanges objects in levels 1 and 2. 3-4 
cC (4)(SWAP 
SYM Selects whether or not symbolic constants evaluate 4-10 


to numbers. 

O (4)(MODES) MISC SYN 
SYSEVAL Evaluates a system object (x). Use only as H-28 
specified by HP applications. 
C Must be typed in. 


-T Move term left. 20-22 
O (QEQUUATON AQ RULES +T 
œ =T Executes 7 ~~ until no change in 20-26 
subexpression. 


0 QUMDA E) «1 
T— Move term right. 20-22 
0 QAAN A RILES T 
(@)T- Executes T+ until no change in 20-26 
subexpression. 
o (4)(EQUATION) (RULES T 
AT Returns percent fraction that v is of y. 12-9 
F REAL aT 
— TAG Tags (labels) an object (y) with a name or H-28 
descriptive string (x). 
C PRG) TYPE: TAG 
TAN Tangent of x. 12-2 
A 
TAIL Returns all but the first element of a list or all but 17-6 


the first character of a string. 


(0; LESE ELEH TEEL 


Operation Index G-47 


Name, Key, Description, Type, and Keys Page 
or Label 
TANH Hyperbolic tangent of zv. 12-3 
A HYE 
TANL Draws the line tangent to the current function at 22-11 
the z-value of the cursor and returns the equation 
of the tangent line to the stack. 
o (4)(@ICTURE i 
TAYLR Calculates the symbolic rth order Taylor's 20-12 
polynomial approximation of an expression (z) in 
a specified variable (y). 
C (SYMBOLIC) TAYLE 
TDELTA Returns the increment between a final temperature H-28 
(y) and an initial temperature (x). This is special 
temperature version of the normal subtraction 
function. 
F ()EQLIB)UTILS TRELT 
TEACH Loads built-in examples. 29-19 
C Must be typed in. 
TEXT Displays stack when display is updated. 
C OU TEST 
THEN Begins true clause. 29-10 
(PRG) DMD CXD ERROR TFERR THEN 
ERER CHok [HEH 
EECH TF THEM 
TICKS Returns system time as binary integer in units of 16-4 
clock ticks (1 tick = zzz seconds). 
¢ GND iier 
TIME Returns current time in 24-hour HH.MMSSs 16-3 
format. 
C (CME) TINE 
— TIME Sets system time to a time (x) specified in 24-hour H-29 
HH.MMSSs format. 
c OTD stan 
TINC Increases or decreases a given temperature (y) by H-29 


a specified temperature increment (v). This is a 
special temperature version of the normal addition 


function. 


PF ODi 


G-48 Operation Index 


Name, Key, Description, Type, and Keys Page 
or Label 
TLINE In PICT, toggles pixels on the line defined by two 9-8 
coordinates (y and zx). 
c PICT TLIHE 
TLINE Switches pixels on and off on line between mark 9-4 
and cursor. 
O (#)(PICTURE) ERIT TI 
TMENU Displays list-defined custom menu (2) but does 30-4 
not change contents of CST. 
c (e) MODES THEN 
TOT Sums each column of matrix in FDAT. H-29 
c (q)GTaT 
TRACE Computes the sum of the diagonal elements (trace) 14-9 
of a square matrix (2). 
c HATE HORM (NXT) TEF 
TRACE Toggles TRACE mode on and off. 22-4 
O (4)(PICTURE) TRACE 
TRANSIO Selects the specified character translation settings H-29 
C OUO IOFAR TRAH 
TRG* Expands trigonometric and hyperbolic functions of 20-25 
sums and differences. 
o (4)(EQUATION)@) RULES TE 
—TRG Replace exponential with trigonometric functions. 20-25 
o (4)(EQUATION) (4) RULE 
TRN Transposes matrix (x). 14-10 
Cc TLRS UF PROM 
TRNC Truncates a number (y) to the specified number 12-10 
ae of decimal Hi or significant digits. 
TRUTH Selects TRUTH plot type. 23-14 
C (ELOT ETYRE: 
TSTR Converts date (y) and time (x) in number form to 16-4 
string form, including the calculated day of the 
week. 
cC (CME) (XT) (XT) 


Operation Index 


G-49 


Name, Key, Description, Type, and Keys Page 
or Label 
TVARS Returns variables containing specified object type H-30 
TVM Displays the TVM menu. 18-13 
c QCD tH 
TVMBEG Sets payment mode to Beginning-of-Period. 
C Must be typed in. 
TVMEND Sets payment mode to End-of-Period. 
C Maust be typed in. 
TVMROOT Solves for the specified TVM variable (x) using the H-30 
values stored in the remaining TVM variables. 
C (4)GOLVE) TMo TYNE 
TYPE Returns the type number of an object (x). H-30 
TYPE TYPE 
c TEST TYPE 
TYPES Display a list of valid object types for the selected 6-6 
field. 
O [input form] TEPES 
UBASE Converts unit object (x) to SI base units. 10-6 
F NTS HERSE 
UFACT Factors a unit (x) from the unit expression of 10-9 
another unit object (y). 
C (4) (ONITS) WF ACT 
UNIT Creates a unit object from a real number (y) and 10-14 
the unit part of a unit object (x). 
TYPE $UNTI 
c amy: 
UNTIL Begins test clause. 29-14 
S 5 on 
UPDIR Makes parent directory the current directory. 5-12 
c Ml) 
UTPC Returns probability that chi-square random 12-5 
variable is greater than x, given the degrees of 
freedom (y) of the distribution. 


G-50 Operation Index 


Name, Key, 
or Label 


Description, Type, and Keys 


UTPF 


Returns probability that Snedecor’s F random 
variable is greater than z, given the numerator (z) 
and denominator (y) degrees of freedom of the 
distribution. 


c PROE u 


UTPN 


Returns probability that normal random variable 
is greater than x, given the mean (z) and variance 
(y) of the distribution. 


c PR 


12-5 


UTPT 


Returns probability that Student’s t random 
variable is greater than x, given the degrees of 
freedom (y) of the distribution. 


c AMMAN FROB UTET 


UVAL 


VAR 


Eliminates the unit part of specified unit object 
(x). 
(#)(UNITS) UAL 


Calculates variance of statistical data columns in 


xDAT. 


c GMD ivAr VAR 


VARS 


Returns list of variables in current directory. 


c AQUO DIR VARS 


VEC 


Switches between vector and array modes. 


o @ GRIN vEt 


VIEW 


(p>) VIEW 


Copies object in current level into appropriate 
environment for viewing. 


0 QUD 


Displays the menu keywords for the current menu. 
If the keywords are variables, their values are 
shown. 


o Mm 


H-31 


VIEW 


Shows the range and current equation while key is 
held. 


o QC Fen VIEN 


22-5 


VPAR 


Returns aan o reserved variable. 


22-15 


Operation Index G-51 


Name, Key, Description, Type, and Keys Page 
or Label 
VTYPE Returns type number of object stored in local or H-31 
global name (z). 
c TYPE GED GRD "TYPE 
VZIN Zooms in vertically. 22-8 
O (4)@ICTURE) 200M (NXT) 
| 
VZOUT Zooms out vertically. 22-8 
o (4)(PICTURE) 200M (NXT): 
V2 Combines two real numbers (y and x) into a 2-D 13-3 
vector or complex number. 
o VECTR ave 
V3 Combines three real numbers into 3-D vector 13-3 
according to the current Coordinate System mode. 
C MTH CTR ais 
| 
vo Separates vector or complex number (x) into its 13-4 
component elements according to current angle 
mode. 
E C MTH)¥ECTE ie 
xW Multiplies the horizontal plot scale by a factor (x). H-31 
C (ELOT) FFA E 
WAIT Halts program execution for specified number of H-32 
seconds (x) or until key pressed. 
Cc IH WATT | 
WHILE Begins indefinite loop. 29-14 
c ERCH WHILE WHILE 
(4) WHILE | Types WHILE REPEAT END H-32 
WID— Increases column width and decrements number of 8-8 
columns. 
O  (@)MATRIX) Hibs 
WID Decreases column width and increments number of 8-8 
columns. 
O  (e>)(MATRIX) HIG 
WIREFRAME [Selects WIREFRAME plot type. 23-28 
c (4)(PLOT S000 PITYPE 
HIREF 


G-52 Operation Index 


Name, Key, 
or Label 


Description, Type, and Keys 


Page 


WSLOG 


Returns a series of strings recording the date, 
time, and cause of each warmstart event. 


C Must be typed in. 


H-32 


EX 


Returns sum of data in independent column in 
S DAT. 


c em 


H-32 


Returns sum of squares of data in independent 
column in X DAT. 


c OCD suns 


H-33 


XCOL 


Specifies independent-variable column (x) in 
matrix in X DAT. 


c (6)GTAT) EFRE COL 


H-33 


XMIT 


Sends the given string (x) through the serial port 
without using the Kermit protocol. 


c OOD SERIA BNIT 


27-18 


XOR 


Logical XOR of two expressions (x and y) that 
evaluate to 1 or 0 or binary XOR combining two 
integers (x and y) or two strings (x and y). 


BASE LOGIC AOR 


F TEST HOR 


o XPON 


Returns exponent of number (7). 


F REAL SPON 


XRECV 


Receives an object via xmodem. 


c OMADE 


H-33 


XRNG 


Specifies the horizontal plot axis display range 
(from y to r). 


c QED FFR 


H-33 


XROOT 


Returns the rth root of a real number y. 


a @&@® 


XSEND 


Sends an object via xmodem. 


c (MUNIT) SEH 


H-33 


X VOL 


Sets the coordinates, Xjeft (y) and Xright (€), 
establishing the width of the 3D plotte volume. 


c QEDED 


H-34 


Operation Index G-53 


DAT. 


Name, Key, Description, Type, and Keys Page 
or Label 
XXRNG Sets the coordinates XXjeg, (y) and XXright (£) H-34 
establishing the width of the 3D target mapping 
range (for GRIDMAP and PARSURFACE plots). 
cC (4)(PLOT Sp WAR 
SARH 
EX*xY Returns sum of products of data in independent H-34 
and dependent columns in Y DAT. 
C (4)GTAT) BUNS ExeY 
(X,Y) Toggles on and off the current cursor coordinates 22-4 
at bottom left of display. 
Oo (#)(PICTURE 
O (4)(PICTURE) # 
X,Y Enters the current cursor coordinates as a complex 22-6 
number onto the Stack. 
(4) (PICTURE) (ENTER) 
o (o)@ICTURE) PICTURE) EDIT (NXT)(NXT) 
Ma Y 
LY Returns sum of data in dependent column in H-34 


c (#)GTAT) SUNS IY 
$n 


establishing the width of the 3D plotting volume. 


c CODER = vFAR 


MEL 


ry’ Returns sum of squares of data in dependent H-34 
column in X DAT. 
c (4)GTAT) SUNS Eyes 
MEE e Se eS a AE | 
YCOL Selects indicated column (x) of Y DAT as H-35 
dependent-variable column for two-variable 
statistics. 
C (#)GTAT) EFAR YOOL 
YRNG Specifies the vertical plot axis display range (from H-35 
y to x). 
C (CELOT) FFARR YRHG 
YSLICE Selects YSLICE plot type. 23-32 
c ao (PLOT) (NXT) BR PIPE 
L SLIL 
YVOL Sets the coordinates, Yfar (y), and Ynear (x) H-35 
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Sets the coordinates YYjar (y) and XXnear (7) 
establishing the width of the 3D target mapping 
range (for GRIDMAP and PARSURFACE plots). 
c (4)(PLOT , VEAR 
TRH 
Autoscales and redraws the graph. 
o (4)(PICTURE) 200M ZAUTO 
Scale the horizontal axis so that every pixel 
represents 0.1. 


o (4)(@ICTURE) 200M 
ZD DECI 

Resets PPAR to the current scale settings. 
o ()(PICTURE) 200M ZOFLT 
Displays input form to set zoom default factors. 


o (#)(PICTURE) 200M ZFACT 


Calculates the gas compressibility factor Z using 
the temperature reduction ratio (y) and the 
pressure reduction ratio (zx). 


F (4)EQUB)UTILS FACT 
Zooms in by a standard factor. 

o (#)(PICTURE) 200M zZIH 
Sets the horizontal scale so every pixel represents 1 
unit. Does not affect vertical scale. 


0 QED zoon 
ZIHTG 


Returns you to the previous zoom factor. 


o (@)(PICTURE) 200" 
=LAST 
Magnifies a rectangular area (that you have 
drawn) to fill the entire screen. 


o (#)(PICTURE) 200M BORE [draw a 


bor] ZOOM 


Zooms out by a standard factor. 
o (@)@ICTURE) Zoon zaut 


Resets the vertical scale to match the horizontal 
scale. 


o QCR) 


ek 


zoon 2s 


Operation Index G-55 


Name, Key, 
or Label 


Sets the horizontal scale so that every ten pixels 

represent 1/2 and sets the vertical scale so that 

every ten pixels represent 1. 

Oo (4)(PICTURE) zoan 
ZTREIG 


Sets the coordinates, Ziow (y) and Znigh (2) 
establishing the height of the 3D plotting volume. 


c EDGE I VFAR 


SOL 


Adds two objects (y and z). 


Switches cursor style between super-imposing and 


inverting cross. Also changes sign of number. 


(4) GICTURE) FZ) 
O ()@ICTURE) EDIT yee 


Add and subtract 1. 


(EQUATION) @) RULES +11 


Double negate and distribute. 


0 @\EMATION @ ruLes GD 


Multiply by 1. 


o EQUATION @) RULES 


Divides one object (y) by another (z). 


Divide by 1. 


o EQUATION @) RULES 


Raise to power 1. 


o QEM @) rues 71 


G-56 Operation Index 


Name, Key, 
or Label 


Description, Type, and Keys 


Page 


< 


Tests whether y < r. 
aT 


FP ETE 


H-36 


IA 


Tests whether y < x. 


F TESA 


ih, 


IV 


Tests whether y > z. 


r (RG) TEST 


ie 


Returns a equation formed of two expressions (y 
and x). 


A (JQ) 


11-4 


Tests whether 
F PRG 


H-38 


Tests whether y # x. 


r 
lr ŒR TEST # 


H-38 


lea of x. 


F PROB 


12-4 


Integrates an expression (y) from t to z with 


respect to the specified variable of integration (7). 


A œ 


H-38 


D» 


Takes the derivative of an expression (y) with 
respect to the specified variable of differentiation 


(e). 
a MO 


H-38 


% 


Computes y percent of v. 
A MTH 


Returns the symbolic constant 7 (or 
3.14159265359 ee on flag —2). 


F ol 


M 


Calculates the sum of an expression (2) evaluated 
a series of times as an index variable (t) moves 


from z to y. 


F_ ooo 


H-39 


Operation Index G-57 


c MC) 


Name, Key, Description, Type, and Keys Page 
or Label 
D+ Adds data point (x) to matrix in X DAT. H-39 
C (q)GTAT) CATA Et 
y- Subtracts data point (x) from matrix in X DAT. H-39 
J Returns square root of x. 12-1 
A 
| Uses a list of names and values (x) to substitutes 20-17 
values for names in an expression (y). 
F  (&)GYMBOLIC)(NXT) | 
1/0 Double-invert and distribute. 20-24 
o (4)(EQUATION) (A RULES 
Pees 
©) Parenthesize neighbors. 20-23 
o (4)(EQUATION) (Q RULES toyo 
(— Expand-subexpression-left. 20-23 
0 @\EQUATION @) RULES 
ce 
æ- Executes i. until no change in 20-26 
subexpression. 
o EQUATION @ ruLes 
œ e 
—() Distribute prefix function. 20-23 
o (4)EQUATION) (AQ RULES 
—) | Expand-subexpression-right. 20-23 
o (4)EQUATION) (4) RULES 
shod 
faa) =) Executes #3 until no change in 20-26 
subexpression. 
o (4)(QUATION) A ELILES (NXT) 
œ + 
ieee Commute arguments. 20-23 
0 QEA = 
— Begins a local variable structure. 29-16 
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H 


ack Diagrams for Selected 


ands 


AMORT Command: Amortizes a loan or investment based upon the 
current amortization settings. 


| Level 1 > Level 3 Level 2 Level 1 | 


| n — principal interest balance 
| m 


AND Function: Returns the logical AND of two arguments. 


Level 2 Level 1 = Level 1 
FEN, FEN, 2 #n 
” string,” ” stringa” _ " string3" 
T/F, T/F — 0/1 
T/F 'symb' = 'T/F AND symb' 
‘symb' T/F = 'symb AND T/F' 
'symb; ' ‘symb, ' — 'symb, AND symb, ' 


APPLY Function: Creates an expression from the specified function 
name and arguments. 


Level 2 Level 1 — Level 1 


{ symb] ... syMbp } ‘name’ = 'name(symb, ... symb,)' 
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ARRY— Command: Takes an array and returns its elements 
as separate real or complex numbers. Also returns a list of the 
dimensions of the array. 


Level1 — Levelnm+1...Level2 Level 1 | 
[ vector ] — Zy o. Zn tement] | 
[E matrix ]] — Zii +++ Znm { Mrow Meg } | 


ATICK Command: Sets the axes tick-mark annotation in the reserved 
variable PPAR. 


Level 1 3 Level 1 
x — 
#n — 
{xy} > 
{ #n wm } = 


BINS Command: Sorts the elements of the independent column 
(XCOL) of the current statistics matrix (the reserved variable X DAT) 
into (moins + 2) bins, where the left edge of bin 1 starts at value £min 
and each bin has width Zwidth- 


Level 3 Level 2 Level 1 — Level 2 . Level 1 


a | 


| Xmin Xwidth oins > [Dina e Poinn DC Mine oink | 


BYTES Command: Returns the number of bytes and the checksum for 
the given object. 


| Level 1 = Level 2 Level 1 | 


| obj >r #Ncnecksum Xsize 
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CENTR Command: Adjusts the first two parameters in the reserved 
variable PPAR, €tmins Ymin 2? and čZmax, maxi, so that the point 
represented by the argument “z, y3 is the plot center. 


| Level 1 = Level 1 


Level3 Level2 Level! — Level2 Level1 | 
“prompt” {icy ... Ch } Npos — obj or result 1 | 
(P ROMpE: { cy... Cn } Npos _ 0 | 


CHR Command: Returns a string representing the HP 48 character 
corresponding to the character code n. 


Level 1 4 Level 1 


| n — " string” 


CKSM Command: Specifies the error-detection scheme. 


Level 1 = Level 1 


Nehecksum 


CLKADJ Command: Adjusts the system time by zx clock ticks, where 
8192 clock ticks equal 1 second. 


Level 1 =e Level 1 
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COL2 Command: Specifies the independent-variable and 
dependent-variable columns of the current statistics matrix (the 
reserved variable DAT). 


Level 2 Level 1 + Level 1 
| Xxcol Xycol FEA 


CORR Command: Returns the correlation coefficient of the 
independent and dependent data columns in the current statistics 
matrix (reserved variable X DAT). 


Level 1 ae Level 1 


a Xcorrelation 


| | 
| = 
| | 


COV Command: Returns the sample covariance of the independent 
and dependent data columns in the current statistics matrix (reserved 
variable X DAT). 


| Level 1 = Level 1 


covariance 


| ‘ _ 


CRDIR Command: Creates an empty subdirectory with the specified 
name within the current directory. 


| Level 1 = Level 1 | 


| ‘global’ = | 


DARCY Function: Calculates the Darcy friction factor of certain fluid 
flows. 


| Level 2 Level 1 => Level 1 | 


| TefD YRe i XDarcy T 
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—DATE Command: Sets the system date to date. 


| Level 1 Sa Leveli1 


date — | 


DECR Command: Takes a variable on level 1, subtracts 1, stores the 
new value back into the original variable, and returns the new value to 
level 1. 


| Level 1 = Level 1 


l 'name' > Xew 


DELALARM Command: Deletes the alarm specified in level 1. 


| Level 1 = Level 1 


index 


| n 


DEPND Command: Specifies the dependent variable (and its plotting 
range for TRUTH plots). 


Level 2 Level 1 = Level 1 
‘global' => 
{ global } — 
{ global Ystart Yena J = 
{ Ystart Yena } = 
Vstart Yend => 


DISP Command: Displays obj in the nth display line. 


| Level 2 i Level 1 z Level 1 


| obj n = 
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DOERR Command: Executes a “user-specified” error, causing a 
program to behave exactly as if a normal error had occurred during 
program execution. 


Level 1 = Level 1 
— = eee l 
Nerror F 
Nerror — 
“error sig 
ie) = 


DTAG Command: Removes all tags (labels) from an object. 


Level 1 = Level 1 


:tag:obj = obj 


EQ— Command: Separates an equation into its left and right sides. 


Level 1 ay Level 2 Level 1 


‘symb, =symb,' = "symb, ' ‘symb, ' 
z — Zz (0) 
'name' — 'name' (0) 
x_unit = x_unit (0) 
'symb' — 'symb' (0) 


ERRM Command: Returns a string containing the error message of 
the most recent calculator error. 


Level 1 l = Level 1 


| 
— “error message" | 
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ERRN Command: Returns the error number of the most recent 
calculator error. 


| Level 1 = Level 1 


can #Nerror 


EYEPT Command: Specifies the coordinates of the eye point in a 
perspective plot. 


| Level 3 Level 2 ‘Level 1 = Level 1 | 


| Xpoint Ypoint 


FO. Function: Returns the fraction of total black-body emissive 


power. 
Level 2 Level 1 = Level 1 
| 
Yiambda XT or, Xpower 
Yiambda ‘symb' a "FOMYambda SYMb)' 
'symb' Xq = ‘FO\(symb,x-+ )' 
‘symb, ' 'symb, ' = 'FOA(symb, ‚symb, )' 


FACT Function: Provided for compatibility with the HP 28. FACT is 


the same as !. 


| Level 1 = Level 1 | 

n — n! | 
| x = r(x+1) | 
| ‘symb' + "(symb)!' | 
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FANNING Function: Calculates the Fanning friction factor of certain 


fluid flows. 
Level 2 Level 1 = Level 1 | 
a/D YRe Ei Xtanning 
Le/D ‘symb' — ‘FANNING(2,/;p,symb)' 
‘symb' Yre -y 'FANNING(syYMb, Yge )' | 
i 
symb, symb, = "FANNING(symb, „symb, )' | 


FINDALARM Command: Returns the alarm index ninder of the first 


alarm due after the specified time. 


Level 1 = Level 1 
date = Ninde 

{ date time } = index 
0 at index 


FREEZE Command: Freezes the part of the display specified by 
display area, SO that it is not updated until a key is pressed. 


Level 1 


z Level 1 


"displayarea 


xH Command: Multiplies the vertical plot scale by tyactor. 


Level 1 


Level 1 
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HEAD Command: Returns the first element of a list or string. 


| Level 1 3 Level 1 
{ obj ... Obj, } — obj, 
"string" = “element, “ 


IFT Command: Executes obj if T/F is nonzero. Discards obj if T/F 
is Zero. 


| Level 2 ‘Level 1 > Level 1 | 


| T/F obj — It depends! | 


IFTE Function: Executes the obj on level 2 if T/F is nonzero. 
Executes the obj on level 1 if T/F is zero. 


Level 3 Level 2 Level 1 a Level 1 


T/F Objirue Objtaise — It depends! 


INCR Command: Takes a variable on level 1, adds 1, stores the new 
value back into the original variable, and returns the new value to 
level 1. 


| Level 1 = Level 1 | 


d 1 
| name a Xincrement 
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INDEP Command: Specifies the independent variable and its plotting 


range. 
Level 2 Level 1 a Level 1 
‘global’ — 
{ global } > 
{ global Xstart Xend } ai 
{ Xstart Xena } = 
Xstart Xend ny 


INPUT Command: Prompts for data input to the command line and 
prevents the user access to stack operations. 


Level 2 Level 1 — Level 1 
"stack prompt” "command-line prompt" = " result" 
"stack prompt" { liSt.gmmand-—tine t = "result" 


KERRM Command: Returns the text of the most recent Kermit 
error packet. 


Level 1 = Level 1 


= “error-message" 


KEY Command: Returns to level 1 a test result and, if a key is 
pressed, returns to level 2 the row-column location tpm of that key. 


Level 1 = Level 2 Level 1 
— Xam 
= (0) | 
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LIBEVAL Command: Evaluates unnamed library functions. 


Level 1 = Level 1 | 


FM unction F | 


LIBS Command: Lists the title, number, and port of each library 
attached to the current directory. 


| Level 1 — Level 1 


| > { title’ Nis Pport = “title” Min Mp ort } 


DLINE Command: Returns an expression representing the best 
fit line according to the current statistical model, using X as the 
independent variable name, and explicit values of the slope and 
intercept taken from the reserved variable X PAR. 


Level 1 = Level 1 


t t 
= SYMbrormula 


LININ Function: Tests whether an algebraic is structurally linear for 
a given variable. 


| Level 2 Level 1 Ee Level 1 | 


| ‘symb' 'name' oo 0/1 


| 


LIST—- Command: Takes a list of n objects and returns them to 
separate levels, and returns the total number of objects to level 1. 


Level 1 > Leveln+1... Level 2 Level 1 


{ obj, ... obh} > obj, ... Obja n 


PESEDRE EA. 
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LR Command: Uses the currently selected statistical model to 
calculate the linear regression coefficients (intercept and slope) for the 
selected dependent and independent variables in the current statistics 
matrix (reserved variable Y DAT). 


| Level 1 zy Level 2 Level 1 


| —> Intercept: x, Slope: x> 


TMATCH Command: Rewrites an expression. {MATCH works from 
bottom up; that is, it checks the lowest level (most deeply nested) 
subexpressions first. 


| Level 2 Level 1 — Level 2 Level 1 | 
'symb;, ' { "SYMB, at! "SYM, epi" } = 'symb,' 0/1 | 
| Syb” { 'symby at! 'SYMb epi 'S¥MBegng' } > 'symb,' 0/1 | 


{MATCH Command: Rewrites an expression. | MATCH works from 
top down; that is, it checks the entire expression first. 


Level 2 Level 1 — Level 2 Level 1 | 
‘symb, ' { 'syMb at 'SYMb,epi' } — ‘symb,' 0/1 | 
‘symb,' { 'symb, 34! SYMB repi 'SYMboona  } > ‘symb,' 0/1 | 


MAX? Command: Finds the maximum coordinate value in each 
of the m columns of the current statistics matrix (reserved variable 
XDAT). 


| Level 1 + Level 1 
| an Xmax | 
i a [Xmaxı Xmax2 - Xmaxm] | 
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MCALC Command: Designates a variable as a calculated value (not 
user-defined) for the Multiple-Equation Solver. 


| Level 1 e Level 1 | 
| ‘name’ — | 
l { list } — 
| "ALL" > 


MEAN Command: Returns the mean of each of the m columns of 
coordinate values in the current statistics matrix (reserved variable 


DAT). 


Level 1 — Level 1 
Ji Xmean 
i [ Xmeanı Xmean2 =- Xmeanm ] 


MEM Command: Returns the number of bytes of available RAM. 


Level 1 — 7 Level 1 


= x 


MIN, Command: Finds the minimum coordinate value in each of 
the m columns of the current statistics matrix (reserved variable 
DAT). 


Level 1 = Level 1 


min 


— [x 


| 


| 
| 
| = x 
| 


mini *min2 v 
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MROOT Command: Uses the Multiple-Equation Solver to solve for 
one or more variables using the equation set in Mpar. 


Level 1 4 Level 1 
‘name’ => x 
" ALL” = 


MSGBOX Command: Creates a user-defined message box. 


| Level 1 ar Level 1 


| "message" = 


MUSER Command: Designates a variable as user-defined for the 
Multiple-Equation Solver. 


Level 1 = Level 1 
‘name’ = 

{ list } _ 

"ALL" = 


NEWOB Command: Creates a new copy of the specified object. 


| Level 1 ay Level 1 


| obj > obj 
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NOT Command: Returns the one’s complement or logical inverse of 
the argument. 


Level 1 = Level 1 
Fen, =£ FEN 
T/F — 0/1 

" string,” = " stringa” 

'symb' — 'NOT symb' 


NUM Command: Returns the character code n for the first character 
in the string. 


| Level 1 = Level 1 


| " string" = n 


NUMX Command: Sets the number of x-steps for each y-step in 3D 
perspective plots. 


| Level 1 = Level 1 
o 


NUMY Command: Sets the number of y-steps across the view 
volume in 3D perspective plots. 


Level 1 + Level 1 | 


ny = | 


NË Command: Returns the number of rows in the current statistical 
matrix (reserved variable X DAT). 


| Level 1 — Levelli | 


| me Nrows | 
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OBJ— Command: Separates an object into its components onto the 
stack. For some object types, the number of components is returned 
to level 1. 


Level 1 — Leveln+1 ... Level 2 Level 1 
(xy) -= x y 
{ Obj, ... obj } > obj, Obja n 
[xy Gya Xa] = xy Xn {n} 
Mx e Xma l > Xii Xmn {mn} 
"obj" — evaluated-object 
'symb' = arg, ... argn n ‘function' 
x_unit = x 1_unit 


:tag:obj ~ obj "tag" 


OR Function: Returns the logical OR of two arguments. 


Level 2 Level 1 = Level 1 
FEN, FEN — #n3 
" string,” " strings" — " stringa” 
T/F; T/F> — 0/1 
T/F ‘symb' > 'T/F OR symb' 
'symb' T/F -> 'symb OR T/F' 
"symp, ' ‘symb, ' = 'symb, OR symb, ' 


ORDER Command: Reorders the variables in the current directory 
(shown in the VAR menu) to the order specified. 


Level 1 = Level 1 


{ global, ... global, } > 
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PARITY Command: Sets the parity value in the reserved variable 
IOPAR. 


| Level 1 = Level 1 


| parity 


PATH Command: Returns a list specifying the path to the current 
directory. 


Level 1 — Level 1 | 


— {HOME directory-name, ... directory-namen } 


PCOV Command: Returns the population covariance of the 
independent and dependent data columns in the current statistics 
matrix (reserved variable X DAT). 


Level 1 — Level 1 


Xpcovariance 


PGDIR Command: Purges the named directory (whether empty or 
not). 


| Level 1 = Level 1 


| ‘global’ = E 


PMAX Command: Specifies <2, y? as the coordinates at the upper 
right corner of the display. 


Level 1 = l Level 1 


(x, y) = 
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PMIN Command: Specifies <2, y} as the coordinates at the lower 
left corner of the display. 


Level 1 $y Level 1 


(x,y) => 


PREDV Command: Returns the predicted dependent-variable value 
Ydependent, based on the independent-variable value tindependent, 

the currently selected statistical model, and the current regression 
coefficients in the reserved variable X PAR. 


Level 1 = Level 1 


Xindependent Yaependent 


PREDX Command: Returns the predicted independent-variable 
value Zindependent, based on the dependent-variable value ydependent; 
the currently selected statistical model, and the current regression 
coefficients in the reserved variable X PAR. 


Level 1 = Level 1 


= Xindependent 


VYaependent 


PREDY Command: Returns the predicted dependent-variable value 
Ydependent, based on the independent-variable value 2independents 

the currently selected statistical model, and the current regression 
coefficients in the reserved variable X PAR. 


Level 1 = Level 1 


x, 


independent Yadependent 
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PROMPT Command: Displays the contents of "prompt" in the 
status area, and halts program execution. 


| Level 1 Z Level 1 


| "prompt" — 


PSDEV Command: Calculates the population standard deviation of 
each of the m columns of coordinate values in the current statistics 
matrix (reserved variable X DAT). 


Level 1 = Level 1 
7 Xosdev 
=r [ Xpsaev1 Xpsdev2 = Xpsdevm ] 


PVAR Command: Calculates the population variance of the 
coordinate values in each of the m columns in the current statistics 
matrix (X DAT). 


Level 1 = Level 1 


Xpva riance 
xX, 


[ Xpvariancet pvariancem ] 


PVIEW Command: Displays PICT with the specified coordinate at 
the upper left corner of the graphics display. 


Level 1 = Level 1 
(x, y) > 
{ #n #m } -> 
{} => 


Stack Diagrams for Selected Commands H-19 


QUOTE Function: Returns its argument unevaluated. 


Level 1 = Level 1 
‘symb' = 'symb' 
obj = obj 


RATIO Function: Prefix form of / (divide) generated by the 
Equation Writer application. 


Level 2 Level 1 = Level 1 

Zi Z2 gý 2 / 22 
[ array ] [[ matrix ]] = [[ array x matrix! ]] 
[ array ] z => [ array/z ] 

Z 'symb' = 'z/symb’ 
'symb' z = 'symb/z' 
‘symb, ' 'symb, ' => ‘symb, / symb, ' 

FEN, n — #N3 

ny FEN > FFN3 

HM FN, 7 FN 
x_unity y_unit, = (x/y)-unit, /units 

x y-unit -— (x/y)-1/unit 
x_unit y = (x/y)_ unit 
‘symb' xX_unit = 'symb/x_unit' 
x.unit 'symb' — 'x_unit/symb' 


RCEQ Command: Returns the unevaluated contents of the reserved 
variable EQ from the current directory. 


| Level 1 —> Level 1 


| = obje 
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RCLALARM Command: Recalls a specified alarm. 


Level 1 a Level 1 


Aniek = { date time Obj ction Xrepeat } 


RCLMENU Command: Returns the menu number of the currently 
displayed menu. 


| Level 1 = Level 1 | 


| = Xmenu | 


RCL}, Command: Returns the current statistics matrix (the contents 
of reserved variable X DAT) from the current directory. 


Level 1 — Level 1 l 


= obj 


RECN Command: Prepares the HP 48 to receive a file from another 
Kermit device, and to store the file in a specified variable. 


Level 1 = Level 1 | 
‘name' = 
"name" — H 
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REPL Command: Replaces a portion of the level 3 target object with 
the level 1 object, beginning at a position specified in level 2. 


Level 3 Level 2 Level 1 — Level 1 
| [E matrix J], Np osition [[ matrix ]]}, —  [[ matrix ]], 
[E matrix ]], {row Neotumn } [I matrix]], —  [[ matrix ]], 
[ vector ], Ng osition [ vector J> — [ vector ], 
{ listyarger } Gi osition { list, } > { listrecun } 
"Stringrarget" Np osition “string,” => "StrINGresyit” 
| Oba rget {zn #m} grob, = DOP ac uit 
grob,, get (x,y) grob, = TOD as uit 
PICT {#én xm} grob; = 
PICT (x,y) grob; = 


RES Command: Specifies the resolution of mathematical and 
statistical plots, where the resolution is the interval between values of 
the independent variable used to generate the plot. 


Level 1 + Level 1 
interval ae 
FM a terval =% 


RKF Command: Computes the solution to an initial value problem 
for a differential equation, using the Runge-Kutta-Fehlberg (4,5) 
method. 


Level 3 Level 2 Level1 —  Level2 _ Level 1 
{ list } Xtol *T final = { list } Xtol 
{ list } { Xol Xhstep } XT final aa { list } Xtol 
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RKFERR Command: Returns the absolute error estimate for a given 
step h when solving an initial value problem for a differential equation 
using the Runge-Kutta-Fehlberg method. 


Level2 Leveli1 — Level4 Level3 Level2 Level 1 


| 
| { list } h -=> { list } h Visia error 


RKFSTEP Command: Computes the next solution step (nert) to an 
initial value problem for a differential equation. 


‘Level 3 Level2 Leveli1 — Level3 Level2 Level 1 


| { list } Xidi h => { list } Xto Next 


ROOT Command: Returns a real number z£root that is a value of the 
specified variable global for which the specified program or algebraic 
object most nearly evaluates to zero or a local extremum. 


Level 3 Level 2 Level 1 = Level 1 


< program > ‘global’ guess = Xroot 
< program > ‘global’ { guesses } as Xroot 
'symb' 'global' guess = Xisot 
'symb' 'global' { guesses } == Xosi 


RRK Command: Computes the solution to an intial value problem 
for a differential equation with known partial derivatives. 


Level3  Level2  Leveli — Level2 Level1 | 
{ list } Xtol XT final = { list } Xtol 
{ list } { Xtol Xnstep } XT tinal E { list } Xtol 
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RRKSTEP Command: Computes the next solution step (Anext) to 
an intial value problem for a differential equation, and displays the 
method used to arrive at that result. 


Lvi4 Lvl3 Lvl2 Lvi1 — Lvl4 Lvi3 Lvi2 Lvi4 


{list} Xol h last = {list} Xoi next Current | 


RSBERR Command: Returns an error estimate for a given step h 
when solving an initial values problem for a differential equation using 
the Rosenbrock method. 


{ fist } h = { dist } h Vawits error | 


SAME Command: Compares two objects, and returns a true result 
(1) if they are identical, and a false result (0) if they are not. 


Level 2 Level 1 = Level 1 


obj, obj> > 0/1 


SCALE Command: Adjusts the first two parameters in PPAR, 

E Emin, Ymin* and &2mar, Ymar, SO that Zscale and Yscale are the new 
plot horizontal and vertical scales, and the center point doesn’t 
change. 


| Level 2 Level 1 a Level 1 
| Xsca te Ysc ale => 


SCONJ Command: Conjugates the contents of a named object. 


Level 1 = Level 1 


‘name’ = 
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SDEV Command: Calculates the sample standard deviation of each 
of the m columns of coordinate values in the current statistics matrix 


(reserved variable X DAT). 


| Level 1 = Level 1 

! os — . 

| =e Xsdev 

| a [ Xsgevi Xsdev2 = Xsdevm ] 


SEND Command: Sends a copy of the named objects to a Kermit 


device. 
Level 1 Level 1 | 
‘name’ > 
{ name, ... namen } — 
{{ name ig PaMenew } name ... } => 


SIDENS Command: Calculates the intrinsic density of silicon as a 
function of temperature, £y. 


Level 1 = Level 1 
XT +4 Xdensity 
x..unit = x_1/cm* 
| 'symb' = 'SIDENS(symb)' 


SINV Command: Replaces the contents of the named variable with 
its inverse. 


Level 1 = Level 1 


'name' — 
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SNEG Command: Replaces the contents of a variable with its 
negative. 


| Level 1 Level 1 


| ‘name’ —> 


SOLVEQN Command: Starts the multiple equation solver for a 
specified set of equations. 


Level 3 Level 2 Level 1 — Level 1 


n m 0/1 = 


START Command: Begins START ... NEXT and START ... STEP 
definite loop structures. 


Level 2 Level 1 — Level 1 
START Xstart Xfi nish => 
NEXT z% 
STEP Xincrement ms 
STEP 'SYMb ncrement” ii 


STOALARM Command: Stores an alarm in the system alarm list 
and returns its alarm index number. 


Level 1 —- Level 1 

Xtime = index 

{ date time } as index 

{ date time obj, ction } = index 

{ date time Obj, ction Xrepeat } = Tindex 
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STO+ Command: Adds a number or other object to the contents of 
a specified variable. 


Level 2 Level 1 y Level 1 | 
obj ‘name’ => 
‘name’ obj = 


STO— Command: Calculates the difference between a number (or 
other object) and the contents of a specified variable, and stores the 
new value to the specified variable. 


Level 2 Level 1 = Level 1 | 
obj ‘name’ — | 
‘name’ obj — | 


STO» Command: Multiplies the contents of a specified variable by a 
number or other object. 


Level 2 Level 1 = Level 1 
obj ‘name’ = 
'name' obj = 


STO/ Command: Calculates the quotient of a number (or other 
object) and the contents of a specified variable, and stores the new 
value to the specified variable. 


Level 2 Level 1 = Level 1 
obj ‘name' = 
'name' obj — 
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STOZ Command: Stores obj in the reserved variable X DAT. 


Level 1 = Level 1 


obj — 


—STR Command: Converts any object to string form. 


| Level 1 a$ Level 1 


| obj —> "obj" 


SYSEVAL Command: Evaluates unnamed operating system objects 
specified by their memory addresses. 


Level 1 mn Level 1 


adress md 


—Tag Command: Combines objects in levels 1 and 2 to create 
tagged (labeled) object. 


Level 2 Level 1 — Level 1 
obj "tag" = :tag:obj 
obj ‘name’ — :name: obj 
obj x — :x:obj 


TDELTA Function: Calculates a temperature change. 


Level 2 Level 1 — Level 1 
x y E Xgelta 
x_unitl y—unit2 — XuNItL gaits 
x_unit ‘symb' => "TDELTA(x_unit,symb)' 
'symb' y_unit — 'TDELTA(symb,y_unit)' 
‘symb, ' "symb, ' > “"TDELTA(symb, „symb, )' 
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TIME Command: Returns the system time in the form HH.MMSSs. 


| Level 1 = Level 1 


- 
i = time | 


TINC Command: Calculates a temperature increment. 


Level 2 Level 1 = Level 1 

Xinitial Yaeita is Xinat 

x_unitl y-unit2j eita — x_unitls nat 

x_unit ‘symb' = 'TINC(x_unit,symb)' 

'symb' y_unitgeita = 'TINC(symb,y_unitg oj¢4)' | 
'symb; ' 'symb, ' = 'TINC(symb, ,symb,")' 


TOT Command: Computes the sum of each of the m columns of 
coordinate values in the current statistics matrix (reserved variable 
Si DAT). 


| Levelli > Level 1 
| = Xsum 
| Z [ Xumi Xsum2 > Xsumm ] 


TRANSIO Command: Specifies the character translation option. 
These translations affect only ASCII Kermit transfers and files printed 
to the serial port. 


Level 1 = Level 1 


option 
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TVARS Command: Lists all global variables in the current directory 
that contain objects of the specified types. 


Level 1 — Level 1 
ype > { global ... } 
{ Mype = } > { global ... } 


TVMROOT Command: Solves for the specified TVM variable using 
values from the remaining TVM variables. 


Level 1 = Level 1 


t ; t 
TVM variable = XTVM variable 


TYPE Command: Returns the type number of an object. 


Level 1 > Level 1 
obj — ype 
Ln 
Object Type Numbers 
Object Type Object Type 
User Objects: Directory 15 
Real number (6) Library 16 
Complex number 1 Backup object 17 
Character string 2 Built-in Commands: 
Real array 3 Built-in function 18 
Complex array 4 Built-in command 19 
List 5 g 
System Objects: 

3 Sig MAG a System binary 20 
ee kee 8 Extended real 21 

eee i Extended complex 22 
Algebraic object 9 Linked area 23 
Binary integer 10 Okaracter 4 24 
Graphics object 11 Code obiact 25 
Tagged object < Library data 26 
Unit ohjeçt ee External object 26-31 
XLIB name 14 
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VAR Command: Calculates the sample variance of the coordinate 
values in each of the m columns in the current statistics matrix 


(DAT). 


Level 1 = Level 1 
mes Xvariance 
rs [ Xyariance1 Xvariancem ] 


VARS Command: Returns a list of all variables’ names in the VAR 
menu (the current directory). 


| Level 1 = Level 1 


| — { global, ... global, } | 


VTYPE Command: Returns the type number of the object contained 
in the named variable. 


Level 1 = Level 1 
i $ 
name _ My pe 
‘port © PAME backup = type 
Noort | Mibrary = Mype 


+W Command: Multiplies a plot’s horizontal scale by 2yactor- 


| Level 1 — Level 1 


| Mactor 
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WAIT Command: Suspends program execution for specified time, or 
until a key is pressed. 


Level 1 = Level 1 
x = 
0 — Xkey 
—iİ _ Xkey 


WHILE Command: Starts the WHILE ... REPEAT... END 
indefinite loop structure. 


Level 1 a Level 1 


| 
| 
| WHILE = 
REPEAT T/F = 
END ar 


WSLOG Command: Returns four strings recording the date, time, 
and cause of the four most recent warmstart events. 


Level 1 =a Level 4 ... Level 1 


Sr "1094 104 bes "iog, u 


2X Command: Sums the values in the independent-variable column 
of the current statistical matrix (reserved variable X DAT). 


Level 1 = Level 1 


| = Xsum 
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2X°2 Command: Sums the squares of the values in the 
independent-variable column of the current statistical matrix (reserved 


variable X DAT). 


Level 1 = Level 1 


= Xsum 


Ee a 


XCOL Command: Specifies the independent-variable column of the 
current statistics matrix (reserved variable X DAT). 


| ‘Level 1 z Level 1 | 


| 
| Neol z | 


XRECV Command: Prepares the HP 48 to receive an object via 
XModem. The received object is stored in the given variable name. 


Level 1 = Level 1 


‘name’ = 


XRNG Command: Specifies the z-axis display range. 


Level 2 Level 1 = Level 1 | 


Xmin Xmax = | H; 


XSEND Command: Sends a copy of the named object via XModem. 


Level 1 3 Level 1 | 


‘name’ — | 
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XVOL Command: Sets the width of the view volume in the reserved 
variable VPAR. 


Level 2 Level 1 = Level 1 


Xieft Xight 


XXRNG Command: Specifies the x range of an input plane (domain) 
for GRIDMAP and PARSURFACE plots. 


| Level 2 Level 1 = Level 1 | 


| Xmin Xmax = | 


XX«xY Command: Sums the products of each of the corresponding 
values in the independent- and dependent-variable columns of the 
current statistical matrix (reserved variable X DAT). 


Level 1 = Level 1 


hi Xsum 


ZY Command: Sums the values in the dependent variable column of 
the current statistical matrix (reserved variable X DAT). 


Level 1 = Level 1 


Ei Xsum 


»Y°2 Command: Sums the squares of the values in the dependent 
variable column of the current statistical matrix (reserved variable 


EDAT). 


Level 1 = Level 1 


— Xsum 
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YCOL Command: Specifies the dependent variable column of the 
current statistics matrix (reserved variable Y;DAT). 


Level 1 = Level 1 | 


| Nool 


YRNG Command: Specifies the y-axis display range. 


Level 2 Level 1 zy Level 1 


Ymin Ymax =E 


YVOL Command: Sets the depth of the view volume in the reserved 
variable VPAR. 


Level 2 Level 1 = Level 1 | 


Ynear Year =F | 


YYRNG Command: Specifies the y range of an input plane (domain) 
for GRIDMAP and PARSURFACE plots. 


Level 2 Level 1 = Level 1 | 


| Ynear Ytar = | 


ZFACTOR Function: Calculates the gas compressibility correction 
factor for nonideal behavior of a hydrocarbon gas. 


| Level2 Levelt > Level 1 
XTr Ypr = XZ factor 
Xr, 'symb' = 'ZFACTOR(x,,,symb)? 
'symb' Yer — 'ZFACTOR(symb,yp,)' 
"symb,' 'symb, ' = ‘'ZFACTOR(symb, „symb, )' 
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ZVOL Command: Sets the height of the view volume in the reserved 
variable VPAR. 


| Level 2 Level 1 z Level 1 


| Xow Xhigh 


< Function: Tests whether one object is less than another object. 


Level 2 Level 1 = Level 1 
x y — 0/1 
FEN, FEN = 0/1 
" string,” " strings" — 0/1 
x 'symb' => "x<symb' 
‘symb' x + 'symb<x' 
‘symb, ' ‘symb, ' < 'symb, <symb,' 
x_unity y-unit = 0/1 
x_unit 'symb' = 'x_unit<symb' 
‘symb' x-unit = 'symb<x_unit' 


< Function: Tests whether one object is less than or equal to another 


object. 
Level 2 Level 1 = Level 1 
x y = 0/1 
#n, #n, = 0/1 
" string,” " strings” = 0/1 
x 'symb' — 'x < symb' 
'symb' x — ‘symb < x' 
'symb; ' 'symb, ' = ‘symb, < symb,' | 
x_unity y-unitz — 0/1 | 
x unit 'symb' = 'x unit < symb' | 
‘symb' x_unit > ‘symb < x_unit' 
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> Function: Tests whether one object is greater than another object. 


| Level 2 Level 1 = Level 1 
| x y — 0/1 
#n #n = 0/1 
| “string,” ” strings” = 0/1 
| x 'symb' = 'x>symb' 
| 'symb' x > "symb>x' 
‘symb, ' ‘symb, ' — ‘symb, >symb,' 
| x_unit, y_unit, > 0/1 
x_unit 'symb' > 'x_unit>symb' 
| 'symb' x_unit = 'symb>x_unit' 


> Function: Tests whether one object is greater than or equal to 
another object. 


Level 2 Level 1 — Level 1 
x y = 0/1 
FEN, FEN => 0/1 
" string," " strings” = 0/1 
x ‘symb' = 'x > symb' 
'symb' x < 'symb > x' 
| "symb, ' 'symb, ' = ‘symb, > symb,' 
| x-unit, y-unit, = 0/1 
x_unit ‘symb' = "x_unit > symb' 
| 'symb' x_unit + ‘symb > x_unit' | 
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== Function: ‘Tests if two objects are equal. 


Level 2 Level 1 — Level 1 
| obj, Obj, = 0/1 
(x,0) x = 0/1 
x (x,0) = 0/1 
z 'symb' = 'z==symb' 
'symb' Zz = ‘symb==z' 
| ‘symb, ' ‘symb, ' = ‘symb, ==symb,' 


+ Function: Tests if two objects are not equal. 


Level 2 Level 1 => Level 1 
obj, obj, — 0/1 
(x,0) x > 0/1 
x (x,0) => 0/1 
z 'symb' = 'z 4 symb' 
'symb' Z — 'symb # z' 
'symb; ' ‘symby ' = ‘symb, # symb, ' 


J Function: Integrates an integrand from lower limit to upper limit 
with respect to a specified variable of integration. 


| Level 4 Level 3 Level2 Level1 — Level 1 


lower limit upper limit integrand ‘name’ — 'SYMBintegral 


ð Function: Takes the derivative of an expression, number, or unit 
object with respect to a specified variable of differentiation. 


| Level 2 Level 1 = Level 1 
| ‘symp, ' ‘name’ = 'symb, ' 
z 'name' = (8) 
x_unit 'name' => o 
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2 Function: Calculates the value of a finite series. 


NEE eae eee se 5 
| Level 4 Level 3 Level 2 Level i — Level 1 | 
| 
| ‘indx' Xinit Kaeo smnd — Xsum 
| ‘indx ‘init’ Xenal smnd — 'S(indx=init,x,,,,,,smnd)' 
‘indx' Xinit ‘final’ smnd —> 'S(indx=x,,,,,final,smnd)' 
‘indx : 


init! ‘final’ smnd — 'E(indx=init, final,smnd)' 


2+ Command: Adds one or more data points to the current 
statistics matrix (reserved variable X DAT). 


Levelm ... Level 2 Level 1 — Level 1 | 
z | 

[xi Xp... Xm J = 

Lxi Xm TL Xa. Xam I > 

X4 Xm=1 Xm a 


2— Command: Returns a vector of m real numbers (or one number x 
if m = 1) corresponding to the coordinate values of the last data point 


entered by £+ into the current statistics matrix (reserved variable 
EDAT). 


= Level 1 
— X 
= [xX XQ. Xm J 
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index 


Index 


Special characters 

X annunciator, 1-2 

Gal fad annunciators, 1-2, 1-6 

d annunciator, 1-2, 2-2 

(€) annunciator, 1-2, 26-4, A-1, 
A-4 

> annunciator, 1-2 

iUSE annunciator, 1-3, 30-5 

kar annunciator, 1-3, 12-11, 
13-2 

Fie annunciator, 1-3, 12-11, 
13-2 

# cursor, 2-12 

@ cursor, 2-12 

È character, 2-7 

€ character 

complex number separator, 
12-12 
vector separator, 4-4, 13-3 

= character, 11-4, 18-1, 22-1 

& wildcard, 20-28, 28-4 

character, A-3 

delimiter, 15-1 

delimiter, 10-2 


4 


in fraction conversions, 16-6 

numeric value, A-2 

symbolic constant, A-2 
XDAT 

reserved variable, 5-6 


XPAR 
plots and, 22-16 
reserved variable, 5-6 
statistical parameters, 21-12 


A 


absolute value, 12-9, 12-13 
accuracy 
of integrals, 20-6 
of linear solutions, 14-17 
acknowledging alarms, 26-4 
alarms 
acknowledging, 26-4 
annunciator, 26-4 
appointment type, 26-2 
controlling beeper, 26-6 
control type, 26-2 
index number, 26-4 
no response needed, 26-4 
not responding, 26-4 
past due, 26-4 
repeating, 26-6 
responding to, 26-4 
saving, 26-5 
stopping repeating, 26-5 
types, 26-2 
ALG annunciator, 1-3 
Algebraic-entry mode, 2-8 
Algebraic/Program-entry mode, 
2-9 


Index-1 


algebraics 

action in programs, 29-2 

array elements in, 14-12 

as graphics objects, 7-13 

as strings, 7-14 

collecting terms, 20-18 

converting to graphics objects, 
7-13 

converting to strings, 7-14 

creating graphics objects from, 
9-9 

delimiters, 2-6 

differentiating, 20-9 

editing in command line, 7-10 

editing in Equation Writer, 
7-9 

editing subexpressions, 7-10 

entering, 2-6, 7-3 

entry modes, 2-8, 2-9 

evaluating, 11-3 

evaluating selectively, 20-17 

expanding terms, 20-18 

general solutions, 20-16 

in local variable structure, 
29-3, 29-16 

inserting stack objects, 7-11 

integrating numerically, 20-1 

integrating symbolically, 20-7 

plotting, 22-1 

precedence of operators, 11-3 

principal solutions, 20-16 

rearranging, 20-17, 20-27 

replacing subexpressions, 
7-12 

showing hidden variables, 
20-17 

solving graphically, 22-10 

solving numerically, 22-10 

solving symbolically, 20-14, 
20-15 


Index-2 


subexpressions, 7-10, 7-12, 
20-18, 20-19 
types, 11-4, 18-1 
unit objects in, 10-9 
algebraic syntax, 11-2 
in local variable structures, 
29-4 
user-defined functions, 11-8 
algebraic transformations 
built-in, 20-19 
conditional, 20-28 
user-defined, 20-27 
wildcards in user-defined, 
20-27, 20-28 
Alpha-entry mode, 2-2 
alpha keyboard 
diagram, 2-3 
locking lowercase, 2-4 
locking on, 2-4 
operation, 1-4, 2-2 
setting automatic lock, 4-9 
ALRMDAT 
reserved variable, 5-6 
amortization (TVM) 
calculations, 18-13, 18-19 
display mode, 18-19 
payment modes, 18-14, 18-19 
analytic functions, 11-1 
angle modes, 4-3 


affect complex numbers, 12-12 


affect implied units, 25-11 
affect trig functions, A-2 
affect vectors, 4-4, 13-3 
annunciators for, 1-3 
changing, 4-4 
Degrees, 4-3 
Grads, 4-3 
Radians, 4-3 

angles 
converting, 12-7 


dimensionless units, 10-7, 
10-8 
HMS format, 12-7 
angular units 
converting, 10-7 
animation 
graphics objects, 9-10 
YSLICE plots, 23-23, 23-33 


annunciators 


alarm (), 1-2, 26-4 
ALG, 1-3 

alpha a, 1-2 

busy X, 1-2 

HALT, 1-3 

indicate status, 1-1 
I/O >, 1-2 

listed, 1-2 


Polar/Cylindrical mode RAZ, 


1-3 
Polar/Spherical mode RA. A, 
1-3 

PRG, 1-3 

RAD, 1-3 

shift keys Ball fad, 1-2, 1-6 

WISER, 1-3 

user flags (i 2 3 4 5), 1-8 
antiderivatives, 20-30 
application cards 

expand ROM, 5-1 

installing, 28-9, 28-12 

removing, 28-14 

ROM-based libraries, 28-6 
applications, 1-6 

CHARS, 1-6 

command menus and, 1-7 

EQ LIB, 1-6 

I/O, 1-6 

LIBRARY, 1-6 

MEMORY, 1-6 

MODES, 1-6 


Index ; 


PLOT, 1-6 
SOLVE, 1-6 
STACK, 1-6 
STAT, 1-6 
SYMBOLIC, 1-7 
TIME, 1-7 
UNITS, 10-1 
appointment alarms, 26-2 
arcs 
drawing, 9-8 
arguments, 3-1 
bad, A-3 
multiple, 3-2 
on stack, 3-1 
recalling last, 3-5 
stack syntax, 3-1 
too few, A-3 
arithmetic 
functions, 12-1 
with arrays, 14-11 
with temperatures, 10-11 
with time, 16-4 
with units, 10-7, 10-11 
arrays 
applying functions to, 14-13 
arithmetic, 14-11 
calculations, 14-11 
column norm, 14-8 
combining, 14-13 
constant, 14-2 
converting complex to real, 
14-13 
converting real to complex, 
14-13 
creating special, 14-2 
dimensions, 14-8 
disassembling, 14-13 
editing, 8-5 
entering, 2-6 
entering with MatrixWriter, 
8-2, 14-1 


index-3 


extracting columns, 14-6 
extracting elements, 8-8, 14-7 
extracting real part, 14-14 
extracting rows, 14-6 
Frobenius norm, 14-8 

in algebraics, 14-12 
inserting columns, 14-5 
norms, 14-8 

one-column, 8-1, 8-8 
one-row, 8-1, 8-8 

printing, 27-2 

random, 14-3 
redimensioning, 14-10 
replacing elements, 14-7 
row norm, 14-8 

spectral norm, 14-8 
swapping columns, 14-6 
swapping rows, 14-6 
vectors, 8-1 


B 
b (binary base marker), 15-1 
backslash translations, 27-16 
backspace 
in command line, 2-8 
in Equation Writer, 7-10 
backup identifiers, 28-3 
backup objects 
all user memory, 28-5 
creating, 28-3 
directories, 28-3 
evaluating, 28-4 
identifiers, 28-3 
in custom menus, 30-2 
in independent memory, 28-3 
in port 0, 28-3 
listing, 28-4 
moving to port 0, 28-16 
moving to RAM card, 28-17 
purging, 28-4 
recalling, 28-3 


Index-4 


restoring memory from, 28-6 
wildcards, 28-4 
BAR plots, 23-17 
from Statistics, 23-19 
base (binary) 
affects display, 15-1 
options, 15-1 
setting, 15-1 
typing, 15-2 
BASE menu, 15-1, 15-4 
batteries 
calculator, A-4 
changing (calculator), A-5 
changing (RAM card), A-7 
disposing, A-6, A-8 
in new RAM cards, 28-10 
low-battery warning, A-4 
preserve RAM-card, 28-15 
RAM card, A-4 
types, A-5 
when to replace, 28-11, A-4 
beeper 
controlling, 4-10 
for alarms, 26-6 
Begin mode (TVM), 18-14, 
18-19 
best editing environment, 2-11, 
3-7 
binary integers 
as pixel coordinates, 9-7 
bases, 15-1 
bits displayed, 15-2 
bits lost, 15-2 
calculations, 15-2, 15-3 
converting to real integers, 
15-3 
delimiters, 15-1 
displaying, 15-1 
entering, 15-2 
internal representation, 15-2 
logic operations, 15-4 


rotating, 15-5 
shifting, 15-5 
boxes 
drawing, 9-8 
branching structures 
conditional structures, 29-10 
loop structures, 29-12 
program element, 29-3 
break (serial), 27-18 
buffer (serial), 27-18, 27-19 
“building-block” programs, 29-5 
bytes 
available memory, A-1 
of built-in memory, 5-1 


C 


cable (serial), 27-7 
calculation form (Equation 
Library) 
equations, 25-4 
calculator 
battery type, A-5 
environmental limits, A-4 
fixing problems, A-1 
halting, 5-16 
questions about, A-1 
repair service, A-16 
testing, A-9, A-10, A-11, 
A-12, A-13, A-14 
warranty, A-15 
won’t turn on, A-9 
capital letters 
keying in, 1-5 
“case” branching, 29-11 
catalogs 
Equation Library, 25-1 
chain calculations, 3-3 
character codes 
backslash translations, 27-16 


characters 
alpha keyboard diagram, 2-3 
backslash translations, 27-16 
keying in, 2-2 
size in graphics objects, 9-9 
uppercase and lowercase, 2-4 
viewing keystrokes, 2-5 
viewing numbers, 2-5 
CHARS application, 1-6, 2-4 
checksums 
HP 48-to-HP 48, 27-1 
verify backup objects, 28-3 
chi-square distribution, 12-5 
circles 
drawing, 9-8 
plotting, 23-11 
clearing 
flags, 4-8 
memory, 5-17 
stack, 3-5 
user keys, 30-6 
clock 
displaying, 4-10 
format options, 16-1, 26-1 
ticks, 16-4 
column vectors, 8-1, 8-8 
combinations, 12-4 
comma 
complex number separator, 
12-12 
fraction mark, 4-6 
command line 
arguments go on stack, 3-1 
comments in, 2-7 
cursor keys, 2-8 
deleting, 1-8 
editing, 2-1, 2-8 
editing environment, 2-12 
entering objects, 2-5 
entry modes, 2-8 
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Index 


insert and replace modes, 
2-12 
inserting stack object, 3-9 
keying in special characters, 
2-4 
multiple arguments, 3-2 
multiple objects, 2-7 
operation, 1-4, 2-7 
processing, 2-8 
recalling previous, 2-10 
stack and, 1-4 
using in EquationWriter, 7-10 
command menus 
applications and, 1-7 
commands 
applying to lists, 17-2, 17-3 
fraction conversion, 16-5 
general math, 12-1 
in custom menus, 30-2 
in programs, 29-2 
stack syntax, 3-1 
subset of operations, 11-1 
type of object, 11-1 
comments in command line, 
2-7 
complex conjugates, 12-13 
complex numbers 
as plot coordinates, 9-7 
assembling from real numbers, 
12-14 
calculations, 12-13 
conjugates, 12-13 
converting to real numbers, 
12-13, 12-14 
coordinate modes, 12-11 
delimiters € 3, 12-12, 13-3 
disassembling into real 
numbers, 12-14 
displaying, 12-11 
entering, 12-12 
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from real-number calculations, 
12-13 
internal representation, 12-12 
normalized, 12-12 
polar components, 12-11 
rectangular components, 
12-11 
compound-interest calculations 
(TVM), 18-13 
computer 
connecting to HP 48, 27-7 
file names, 27-11 
restoring HP 48 memory, 
27-13 
conditional structures 
“case” branching, 29-11 
error branching, 29-15 
“if? branching, 29-10, 29-15 
program element, 29-3 
test commands in, 29-10 
CONIC plots, 23-11 
default step size, 23-13 
plotting ranges, 24-3 
valid equations, 23-11 
conjugate complex numbers, 
12-13 
conjugates (matrices), 14-14 
constants 
built-in, 11-4 
in equations, 25-12 
list of, 25-12 
numeric, 11-4 
symbolic, 11-4, 11-5 
Constants Library, 25-12 
continuing program execution, 
29-9 
control alarms, 26-2 
converting 
algebraics to graphics objects, 
7-13 
algebraics to strings, 7-14 


angular units, 10-7 

binary integers to real integers, 
15-3 

complex arrays to real arrays, 
14-13 

complex numbers to real 
numbers, 12-13, 12-14 

dates to numbers, 16-1, 16-2 

dates to strings, 16-4 

decimal format to HMS, 12-7, 
16-3 

degrees to radians, 12-7 

HMS format to decimal, 12-7, 
16-3 

numbers to fractions, 16-5 

objects to graphics objects, 
9-9 

pixels to user-units, 9-9 

radians to degrees, 12-7 

real arrays to complex arrays, 
14-13 

real numbers to binary 
integers, 15-3 

real numbers to complex 
numbers, 12-14 

stack displays to graphics 
objects, 9-10 

temperature units, 10-10 

times to numbers, 16-1, 16-3 

units, 10-6 

user-units to pixels, 9-9 

coordinate modes 

affect complex numbers, 12-11 

affect vectors, 4-4, 13-1, 13-3 

annunciators for, 1-3 

changing, 12-11, 13-2 

Cylindrical, 4-5, 12-11, 13-1 

Polar, 4-4, 12-11, 13-1 

Rectangular, 4-4, 12-11, 13-1 

Spherical, 4-5, 12-11, 13-1 
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coordinates 
pixel, 9-7 
user-unit, 9-7 
coordinates (plot), 9-7, 9-9 
counters 
loop structures, 29-12, 29-13 
negative steps, 29-13, 29-14 
critical points 
viewing in graph, 22-11 
cross products, 13-4 
CST 
reserved variable, 5-6, 30-1 
CST menu, 30-1 
current directory 
changing, 5-8 
determines VAR menu, 5-4 
displayed in status area, 1-1, 
5-3 
path of, 1-1, 5-3 
variables created in, 5-6 
current equation, 5-6 
solving, 22-10 
current statistical matrix, 21-1 
cursor 
command line, 2-12 
coordinate modes, 22-4 
displaying coordinates, 22-4 
insert, 2-12 
moving, 1-7 
replace, 2-12 
cursor keys 
using, 1-7 
custom menus 
creating, 30-1 
custom labels, 30-3 
in each directory, 30-3 
in SOLVR environment, 18-9 
objects in, 30-1 
shifted keys, 30-4 
switching, 30-3 
typing aids in, 30-1 
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user-defined units, 10-14, 
25-15 
Cylindrical coordinate mode, 
4-5, 12-11, 13-1 
Cylindrical mode, 4-10 


D 


d (decimal base marker), 15-1 
date 
converting to number, 16-1, 
16-2 
converting to string, 16-4 
displaying, 4-10 
format options, 16-1, 26-1 
setting the current, 16-1 
debugging programs, 29-8, 29-9 
decimal format 
converting to HMS, 12-7, 
16-3 
decimal places 
number of displayed, 4-3 
defining 
user-defined functions from 
equations, 11-7 
variables from equations, 
5-13, 11-4 
defining procedures 
local variables in, 29-18 
local variable structures, 
29-16 
degrees 
converting to radians, 12-7 
Degrees angle mode, 4-3 
Degrees mode, 4-10 
delimiters 
entering, 2-5 
' for algebraics, 2-6 
E 1 for arrays, 2-6, 8-1 
# for binary integers, 15-1 
€ 3 for complex numbers, 
12-12 
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£ ł for matrices, 2-6, 8-1 
« = for programs, 29-1 
.. for unit objects, 10-2 
E J for vectors, 2-7, 4-4, 8-1, 
13-3 
list of, 2-6 
prevent evaluation of names, 
5-14 
dependent variable 
plotting range, 24-3 
derivatives 
calculating numerically, 20-9 
calculating symbolically, 
20-10 
“der” variables, 5-6, 20-11 
in Equation Writer, 7-5 
in PICTURE environment, 
22-10, 22-11 
user-defined, 20-11 
“der” names, 20-11 
variables, 5-6 
DIFF EQ plots, 19-7, 23-11 
initial values, 19-8 
variables, 19-8 
differential equations 
initial value problems, 19-2 
plotting second-order, 19-12 
plotting solutions, 19-7 
plotting stiff, 19-9 
plotting vector-valued, 19-12 
reducing order of, 19-5, 19-12 
second-order, 19-5 
solving, 19-1 
stiff, 19-4 
vector-valued, 19-5, 19-12 
differentiation 
implicit, 20-12 
of algebraics, 20-9 
dimensional consistency, 25-10 
dimensionless units, 10-7 


directories, 5-3 
backing up, 28-3 
changing current, 5-8 
creating, 5-7 
current directory, 5-3 
custom menu in, 30-3 
Equation Library, 25-3 
evaluating variables 

containing, 5-13 

in custom menus, 30-1 
paths, 5-4 
root directory, 5-3 
stored in variables, 5-4 
variables in, 5-4 

display 
annunciators, 1-1, 1-2 
command line, 1-4 
current path, 1-1 
messages, 1-1 
number format, 4-2 
organization, 1-1 
showing clock, 26-1 
stack levels, 1-3 
status area, 1-1 

display form (Equation Library) 
equations, 25-4 

display modes 
affect fraction conversions, 

16-5 

affect rounding, 12-9 
affect truncating, 12-9 
changing, 4-3 
control number format, 4-2 
Engineering, 4-2 
Fix, 4-2 
Scientific, 4-2 
Standard, 4-2 

display ranges 
PARAMETRIC plots, 23-8 
plotting ranges and, 24-3 
POLAR plots, 23-5 
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TRUTH plots, 23-15 
“do” looping, 29-14 
dot products, 13-4 
duplicating stack entries, 3-4 


E 
E (in numbers), 2-2, A-2 
editing 
algebraics, 7-9 
arrays, 8-5 
canceling changes, 2-10 
in Equation Writer, 7-9 
in MatrixWriter, 8-5 
inserting objects into 
algebraics, 7-11 
programs, 29-8 
stack objects, 2-10 
statistical data, 21-4 
subexpressions, 7-10, 7-12, 
20-20 
user key assignments, 30-8 
variables, 2-10 
EDIT menu, 2-12 
elapsed time 
calculating, 16-4 
ellipses 
plotting, 23-11 
ellipsis (...) in display, A-3 
End mode (TVM), 18-14, 18-19 
Engineering display mode, 4-2 
entry modes 
Algebraic, 2-8 
Algebraic/Program, 2-9 
Alpha, 2-2 
annunciators for, 1-3 
changing manually, 2-9 
command line, 2-8 
Equation Writer, 7-2 
Immediate, 2-8 
Program, 2-9 
environmental limits, A-4 
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environments 
best, 2-11, 3-7 
editing, 2-10 
Equation Writer, 7-2 
exiting, 1-8 
Interactive Stack, 3-6 
Matrix Writer, 8-2 
Selection, 7-10, 20-19 
EQ 
created by Equation Library, 
25-2, 25-6 
FUNCTION plots and, 23-1, 
23-3 
GRIDMAP plots and, 23-34 
PARAMETRIC plots and, 
23-7, 23-9 
POLAR plots and, 23-4 
PR-SURFACE plots and, 
23-36 
reserved variable, 5-6 
SLOPEFIELD plots and, 
23-26 
TRUTH plots and, 23-14 
EQ LIB application, 1-6 
equal sign, 11-4, 18-1, 22-1 
Equation Library, 25-1 
catalogs, 25-1 
chooses solver, 25-2 
entering values for variables, 
25-3 
equation information, 25-4 
interpreting results, 25-10 
Minehunt game, 25-14 
Multiple-Equation Solver, 
25-2 
pictures in, 25-5 
purging variables, 25-5, A-3 
reference, F-1 
setting units options, 25-1, 
25-5 
SOLVE application and, 25-2 
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solving for variables, 25-3 
solving problems, 25-1 
starting solvers, 25-2 
subjects, 25-4, F-1 
titles, 25-4, F-1 
unexpected results, 25-10 
units catalog, 25-5 
units options, 25-5 
user-defined units, 25-15 
uses Multiple-Equation Solver, 
25-6 
variable catalogs, 25-5 
variable names, 25-5 
viewing equations, 25-4 


equations, 11-4, 18-1, 22-1 


arguments to functions, 11-4 

calculating slope of, 22-10 

compared to expressions, 
11-4, 18-1, 22-1 

creating, 2-6 

creating in Equation Writer, 
7-3 

creating user-defined functions 
from, 11-7 

creating variables from, 5-13, 
11-4 

critical points, 22-11 

general solutions, 20-16 

plotting, 22-1 

polynomial approximations, 
20-12, 20-15 

principal solutions, 20-16 

rearranging, 20-17, 20-27 

slope of, 22-11 

solving, 18-2 

solving for unknown variable, 
18-1 

solving graphically, 22-10 

solving linear systems, 14-12, 
14-14, 14-15, 14-17, 14-18 

solving numerically, 22-10 


solving quadratic, 20-15 

solving symbolically, 20-14, 
20-15 

equations (Equation Library) 

calculation form, 25-4 

designing, 25-8 

display form, 25-4 

function limitations, 25-9 

multiple roots, 25-11 

pictures, 25-5 

robust, 25-9 

solving, 25-1 

too many unknowns, 25-8, 
25-10 

unexpected solutions, 25-10 

unused, 25-10, 25-11 

variables in, 25-8 

viewing, 25-4 

Equation Writer, 7-2 

creating equations in, 7-3 

creating unit objects in, 7-6, 
10-4 

editing in command line, 7-10 

editing subexpressions, 7-10 

editing with backspace, 7-10 

entering derivatives, 7-5 

entering exponents, 7-4 

entering fractions, 7-4 

entering integrals, 7-5 

entering math operators, 7-4 

entering names, 7-3 

entering numbers, 7-3 

entering parentheses, 7-5 

entering powers, 7-5 

entering roots, 7-4 

entering summations, 7-5 

entering units, 7-6 

entering variables, 7-3 

entering where function, 7-6 

entry mode, 7-2 

examples, 7-8 


exiting, 7-3 
implicit parentheses, 7-6 
inserting stack objects, 7-11 
modes, 7-2 
operations, 7-13 
replacing subexpressions, 
7-12 
Rules transformations, 20-19 
scrolling mode, 7-2, 7-10, 
7-13 
Selection environment, 7-2, 
7-11, 7-12, 7-18, 20-19 
starting, 7-3 
subexpressions, 7-10 
errors 
causes, 29-15 
conditional structures, 29-15 
controlling beeper, 4-10 
during equation solution, 
25-10 
messages listed, B-1 
numbers for, B-1 
serial I/O, 27-18, 27-19 
trapping, 29-15 
evaluation 
of algebraics, 11-3 
of backup objects, 28-4 
of local variables, 29-17 
of symbolic constants, 11-5 
of test clauses, 29-10, 29-11, 
29-14 
of variable names, 5-13 
preventing for names, 5-14 
exponential functions, 12-2 
exponents 
display format of, 4-3 
fractional, A-2 
in EquationWriter, 7-4 
expressions, 11-4, 18-1, 22-1 


compared to equations, 11-4, 


18-1, 22-1 
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differentiating, 20-9 
integrating numerically, 20-1 
integrating symbolically, 20-7 
plotting, 22-1 
rearranging, 20-17, 20-27 
solving, 18-2 
solving symbolically, 20-14, 
20-15 

extremum 
in SOLVE application, 18-4 
of graph, 22-11 

eyepoint, 23-24 
PR-SURFACE plots, 23-37 
requirements, 23-25 
WIREFRAME plots, 23-30 


F 


factorials, 12-4 
f distribution, 12-5 
fields (input forms), 6-1 
check, 6-2, 6-4 
data, 6-2, 6-3, 6-4 
determining valid object types, 
6-6 
extended data, 6-2, 6-3 
list, 6-2, 6-4 
resetting, 6-6 
selecting, 6-2, 6-3 
types of, 6-2 
files 
backing up memory, 27-12 
choosing names, 27-11 
restoring memory, 27-13 
Finance Solver application, 
18-13 
amortization, 18-19 
payment modes, 18-14 
Fix display mode, 4-2 
fixing problems, A-1 
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flags 
Acknowledged Alarms Saved 
= (—44), 26-5 
Alarm Beep (—57), 26-6 
Alpha Lock (—60), 4-9 
backing up in backup object, 
28-5 
backing up on computer, 
27-12 
clearing, 4-8 
Complex Mode (—19), 12-14 
control modes with, 4-7 
default states, 4-9, D-1 
Infinite Result Exception 
(—22), 14-16 
Numeric Results (—3), 5-13, 
11-5 
Principal Solution (—1), 20-16 
RECV Overwrite (—36), 
27-11 
Repeat Alarms Not 
Rescheduled (—43), 
26-6 
setting, 4-8 
Symbolic Constants (—2), 
11-5 
system, D-1 
testing, 4-8 
user, 4-9 
“for” looping, 29-13 
fractional exponents, A-2 
fractional part of real number, 
12-9 
fraction mark, 4-6 
affects complex numbers, 
12-12 
comma, 4-6 
period, 4-6 
setting, 4-6 


fractions 
converting real numbers to, 
16-5 
in Equation Writer, 7-4 
freeing merged memory, 28-16, 
28-17 
function analysis, 22-9 
FUNCTION plots, 23-1 
default step size, 23-3 
EQ in, 23-1, 23-3 
PICTURE FCN tools and, 
23-1 
TRACE mode, 23-3 
valid equations, 23-1 
functions 
analyzing plots of, 22-9 
angle conversion, 12-7 
applying to arrays, 14-13 
applying to lists, 17-5 
arithmetic (summary), 11-5 
equations as arguments for, 
11-4 
exponential, 12-2 
fraction conversion, 16-5 
general math, 12-1 
hyperbolic, 12-3 
logarithmic, 12-2 
number parts, 12-9 
percent, 12-9 
scientific (summary), 11-5 
subset of commands, 11-1 
trigonometric, 10-8, 12-2, 
A-2 
type of object, 11-1 
user-defined, 11-6, 24-2 
functions of two variables 
plotting, 23-22 
future value (TVM), 18-20 


G 


Gamma function, 12-4 
Gaussian elimination, 14-18 
general solutions 
equations and algebraics, 
20-16 
ISOL and QUAD and, 20-16 
ni and, 20-16 
principal solutions and, 20-16 
st and, 20-16 
specifying, 20-16 
global variables, 25-2, 25-5, 
25-11, A-3 
action in programs, 29-2 
disadvantages in programs, 
29-16 
VAR menu, 5-11 
GRAD annunciator, 1-3, 4-3 
Grads angle mode, 4-3 
Grads mode, 4-10 
Graphics environment 
adding elements, 9-3 
pixel operations, 9-8 
graphics objects 
character size in, 9-9 
creating from algebraics, 7-13 
creating from objects, 9-9 
extracting images, 9-10 
printing, 27-2 
size of, 9-10 
superimposing, 9-9 
viewing in stack display, 9-10 
Greek letters 
keying in, 1-5 
translations, 27-16 
GRIDMAP plots, 23-34 
controlling output display, 
23-34 
EQ in, 23-34 
output grid, 23-22, 23-34 
guarantee, A-15 
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guessed solutions 
help find solution, 25-10, 
25-11 
SOLVE application, 18-1, 
18-3, 18-5 
guesses solutions 
help find solution, 25-11 


H 
h (hex base marker), 15-1 


HALT annunciator, 1-3, 29-9, 
A-3 

halting programs, 29-9 
halting the calculator, 5-16 
hidden variables 

showing, 20-17 
HISTOGRAM plots, 23-17 

from Statistics, 23-18 
HMS format 

converting to decimal, 12-7, 

16-3 

for angles, 12-7 

for time, 16-3 
HOME directory 

backing up, 27-12, 28-5 

restoring, 27-13, 28-6 

switching to, 5-12 
humidity limits, A-4 
hyperbolas 

plotting, 23-11 
hyperbolic functions, 12-3 
HYP menu, 12-3 


| 


JERR (integration uncertainty), 
20-7 
“P branching, 29-10, 29-15 
imaginary part 
of complex matrices, 14-14 
of complex numbers, 12-13 
Immediate-entry mode, 2-8 
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implicit parentheses, 7-6 
independent memory 
backup objects in, 28-3 
expanding, 28-15 
libraries in, 28-8 
port 0, 28-2, 28-3 
independent variable 
plotting range, 24-3 
index number (alarm), 26-4 
infrared port 
testing, A-13 
infrared printers 
printing, 27-2 
setting up, 27-3 
initial value differential equations 
solving, 19-2 
stiff, 19-4 
input forms, 6-1 
commands, 6-7 
creating, 6-7 
determining valid object types, 
6-6 
editing data, 6-4 
entering data from keyboard, 
6-3 
entering lists, 6-3 
entering stored objects, 6-3 
executing, 6-7 
exiting, 6-7 
fields, 6-1 
global changes, 6-7 
labels, 6-1 
navigating in, 6-2 
prompt line, 6-1 
resetting fields, 6-6 
selecting fields, 6-2 
selecting options, 6-4 
SOLVE and PLOT, 6-7 
stack calculations and, 6-5 
titles, 6-1 
using a second, 6-5 


insert cursor, 2-12 
integer part of real number, 
12-9 
integrals 
accuracy, 20-6 
and Taylor polynomials, 20-9 
definite, 20-1, 20-7 
JERR contains uncertainty, 
20-7 
improper, 20-2 
indefinite, 20-9 
in Equation Writer, 7-5 
in PICTURE environment, 
22-10 
limiting accuracy, 20-6 
multiple, 20-5 
of non-integrable expressions, 
20-9 
solving numerically, 20-1 
solving symbolically, 20-7 
uncertainty, 20-6 
integration 
legal symbolic expressions, 
20-7 
numeric, 20-1 
symbolic, 20-7 
integration patterns 
symbolic, 20-30 
Interactive Stack 
editing environment, 3-6 
keyboard, 3-9 
menu, 3-7 
operation, 3-7 
pointer, 3-6 
interest rate (TVM), 18-20 
intermediate results 
using on stack, 3-3 
International System of Units, 
10-2, 10-6 
intersections, 22-10 
inverse functions, 20-15 


inverting 
matrices, 14-10 
I/O 
backing up memory, 27-12 
computer connection, 27-7 
errors, 27-18, 27-19 
file-naming, 27-11 
HP 48-PC, 27-9 
HP 48-to-computer, 27-7, 
27-12 
HP 48-to-HP 48, 27-1 
input buffer, 27-18, 27-19 
Kermit commands, 27-13 
Kermit protocol, 27-9 
non-Kermit commands, 27-15 
parameters for serial printer, 
27-3 
protecting variables, 27-11 
restoring memory, 27-13 
serial commands, 27-15 
serial wiring, 27-7 
testing ports, A-13, A-14 
XON/XOFF pacing, 27-3, 
27-17 
I/O application, 1-6 
I/O menu, 27-18 
IOPAR 


reserved variable, 5-6 


K 


Kermit 
file transfer protocol, 27-9 
packets, 27-13 
sending commands, 27-13 
keyboard 
alpha, 1-5, 2-2 
alpha diagram, 2-3 
alpha left-shifted, 1-5 
alpha right-shifted, 1-5 
assigning user keys, 30-5 
backspacing, 2-1 
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disabling user keys, 30-7 
entering delimiters, 2-5 
entering objects, 2-5 
entering special characters, 
2-4 
Equation Writer, 7-2 
in PICTURE environment, 
22-5 
Interactive Stack, 3-9 
keying in characters, 2-2 
keying in numbers, 2-1 
keystrokes queued, 1-2 
left-shifted, 1-4 
locked up, 30-8, A-9 
math functions, 12-1 
menu keys, 1-8 
multiple functions of, 1-4 
organization, 1-4 
primary, 1-4 
right-shifted, 1-5 
shift keys, 1-4, 1-6 
testing operation, A-11 
unassigning user keys, 30-6 
user keys, 30-4 
key location numbers, 30-5 
keystrokes 
queued, 1-2 
viewing, 2-5 
killing programs, 29-9 


L 


last arguments 
recalling, 3-5 
saving, 4-10 

last command line 
recalling, 2-10 
saving, 4-10 

last stack 
restoring, 3-6 
saving, 4-10 
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letters 
keying in, 2-2 
uppercase and lowercase, 2-4 
LIBRARY application, 1-6 
library objects 
attaching, 28-7, 28-8 
compared to programs, 28-6 
contain objects, 28-6 
detaching, 28-8 
extend command set, 28-6 
identifiers, 28-7 
in independent memory, 28-8 
limiting access, 28-8 
moving to port 0, 28-16 
names, 28-7 
purging, 28-8 
RAM- or ROM-based, 28-6 
setting up, 28-7 
linear equations, 14-12, 14-15, 
14-17, 14-18 
finding “best” solution, 14-15 
matrix equations and, 18-11 
solvable systems, 18-12 
solving systems of, 14-14, 
18-11, 18-12 
Linear System Solver 
allowable systems, 18-12 
interpreting results, 18-12 
testing solution, 18-12 


using, 18-11 
lines 

drawing, 9-8 
lists, 17-1 


action in programs, 29-2 
adding elements in two, 17-3 
appending, 17-1, 17-2 
applying commands to, 17-2 
applying functions to, 17-4, 
17-5 
applying procedures to, 17-5 
applying programs to, 17-4 


concatenating, 17-3, 17-6 

counting elements in, 17-7 

creating from keyboard, 17-1 

creating from stack, 17-1 

dividing two, 17-4 

entering, 2-5 

finding elements, 17-7 

manipulating, 17-6 

multiple-argument commands 
and, 17-3 

multiplying two, 17-4 

placing elements on stack, 
17-6, 17-7 

placing first element on stack, 
17-7 

processing, 17-2 

replacing elements, 17-7 

reversing, 17-6 

sorting, 17-6 

subtracting two, 17-4 

using with input forms, 6-3 

local variables, 29-4 

action in programs, 29-2 

compiled, 29-18 

creating, 29-3, 29-16 

evaluating, 29-17 

exist temporarily, 29-16, 
29-17, 29-18 

in subroutines, 29-18 

naming, 29-16 

using outside of defining 
procedure, 29-18 

local variable structures 

advantages, 29-17 

as user-defined functions, 
29-19 

calculations with, 29-4 

create local variables, 29-16 

defining procedure, 29-16, 
29-18 

entering, 29-16 
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in user-defined functions, 
29-18 

operation, 29-3, 29-16 

program element, 29-3 

syntax, 29-3, 29-16 
logarithmic functions, 12-2 
logical functions, 15-4 
loop structures 

counters, 29-12, 29-13 

definite, 29-12 

“do” looping, 29-14 

“for” looping, 29-13 

indefinite, 29-12 

negative steps, 29-13, 29-14 

program element, 29-3 

“start” looping, 29-12 

test commands in, 29-14 

“while” looping, 29-14 
low-battery warning, A-4 
lowercase letters 

in units, 10-3 

keying in, 1-5, 2-4 
low-memory conditions, 5-18 


M 


mantissas, 4-3 
math operations, 12-1 
matrices, 8-1 
assembling from sequences, 
14-4 
assembling from vectors, 
14-3, 14-4 
augmented, 14-18 
calculations, 14-11 
characterizing, 14-7 
condition number, 14-9 
conjugating, 14-14 
decomposing, 14-21 
determinants, 14-9 
disassembling into elements, 
14-4 
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disassembling into vectors, 
14-4, 14-5 

eigenvalues, 14-20 

eigenvectors, 14-21 

entering, 2-6 

entering with MatrixWriter, 
8-2, 14-1 

extracting diagonal elements, 
14-5 

factoring, 14-21 

Gaussian elimination, 14-18 

identity, 14-2 

ill-conditioned, 14-16 

inserting rows, 14-5 

inverses, 14-16 

inverting, 14-10, 14-18 

rank, 14-9 

reconstructing from singular 
values, 14-22 

row operations, 14-19 

row-reduced echelon, 14-19, 
14-20 

singular, 14-16 

singular values, 14-22 

solving linear equations, 14-14 

spectral radius, 14-9 

statistical data, 21-1 

trace, 14-9 

transforming, 14-18 

transposing, 14-10 


MATRIX menu, 8-8 
Matrix Writer 


cell entry order, 8-5, 8-8 
deleting columns, 8-7, 8-8 
deleting rows, 8-7, 8-8 
editing arrays, 8-5 
entering arrays, 8-2, 14-1 
entering vectors, 8-8 
inserting columns, 8-6, 8-8 
inserting rows, 8-7, 8-8 
MATRIX menu, 8-8 
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setting cell width, 8-5, 8-8 
statistical data, 21-4 
statistical data and, 21-2 
using, 8-2 
maximum 
in SOLVE application, 18-4 
of graph, 22-11 
memory 
amount available, A-1 
automatic cleanup, 5-1, A-3 
backing up in backup object, 
28-5 
backing up to computer, 
27-12 
backup objects in, 28-3 
clearing all, 5-17 
expanding, 5-1, 28-15, 28-16 
low-memory conditions, 5-18 
out-of-memory condition, 
5-20 
plug-in cards, 5-1 
RAM defined, 5-1 
recovering, 5-17, 28-14 
restoring from backup object, 
28-6 
restoring from computer, 
27-13 
ROM defined, 5-1 
user memory defined, 5-1 
MEMORY application, 1-6 
menu descriptions 
CST, 30-1 
EDIT, 2-12 
Interactive Stack, 3-7 
I/O, 27-18 
MATRIX, 8-8 
MTH BASE, 15-1, 15-4 
MTH HYP, 12-3 
MTH PARTS, 12-9 
MTH PROB, 12-4, 12-5 
MTH REAL, 12-7, 12-9 


MTH VECTR, 13-2, 13-4 
PICTURE FCN, 22-10 
PRG STK, 3-11 
RULES, 20-21 
UNITS Catalog, 10-1, 10-2, 
10-6 
UNITS Command, 10-1 
VAR, 5-11 
menu keys 
labels, 1-4 
Multiple-Equation Solver, 
25-3, 25-7 
SOLVE application, 25-3 
using, 1-8 
menu labels, 1-4 
bar indicates submenu, 5-4 
black and white, 25-8 
bottom of display, 1-8 
custom, 30-3 
indicate related variables, 
25-8, 25-10, 25-11 
indicate variable states, 25-8 
indicating submenu, 1-9 
in Equation Library, 25-3 
wrong colors, 25-11 
menus 
custom, 30-1 
displaying, 1-9 
labels in display, 1-4 
list of, C-1 
numbers for, C-1 
pages in, 1-9 
previous menu, 1-10 
selecting functions from, 1-10 
using, 1-10 
messages 
displayed in status area, 1-1 
in SOLVE application, 18-3 
list of, B-1 
low-memory, 5-18 
numbers for, B-1 
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Minehunt game, 25-14 
minimum 


in SOLVE application, 18-4 
of graph, 22-11 


mode names 


1-User, 30-5 

Algebraic-entry, 2-8 

Algebraic/Program-entry, 
2-9 

Alpha-entry, 4-9 

Cylindrical, 4-5, 12-11, 13-1 

Degrees, 4-3 

Engineering, 4-2 

entry (Equation Writer), 7-2 

Fix, 4-2 

Grads, 4-3 

Immediate-entry, 2-8 

Polar, 4-4, 12-11, 13-1 

Program-entry, 2-9, 29-5 

Radians, 4-3 

Rectangular, 4-4, 12-11, 13-1 

Scientific, 4-2 

scrolling (Equation Writer), 
7-2 

selection (Equation Writer), 
7-2 

Spherical, 4-5, 12-11, 13-1 

Standard, 4-2 

User, 30-5 


modes 


angle, 4-3 

command line entry, 2-8 
coordinate, 4-4, 12-11, 13-1 
display format, 4-2 

in Equation Writer, 7-2 
program entry, 29-5 
resetting all, 4-9 

setting, 4-7 


MODES application, 1-6 
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Mopar 
created by Equation Library, 
25-2, 25-6 
MTH BASE menu, 15-1, 15-4 
`: MTH HYP menu, 12-3 
MTH PARTS menu, 12-9 
MTH PROB menu, 12-4, 12-5 
MTH REAL menu, 12-7, 12-9 
MTH VECTR menu, 13-2, 13-4 
Multiple-Equation Solver 
can’t find solution, 25-10 
compared to SOLVE 
application, 25-3 
function limitations, 25-9 
internal process, 25-8, 25-10 
interpreting results, 25-10 
menu actions, 25-3, 25-7 
menu label colors, 25-3, 25-8 
messages, 25-10 
units usage, 25-7 
used by Equation Library, 
25-2, 25-6 
uses root-finder, 25-8 


nt 
general solutions (integer), 
20-16 
reserved variable, 5-6 
names 
action in programs, 29-2 
duplicate, 5-4 
entering, 5-14 
evaluating, 5-13, 5-14 
evaluating variables 
containing, 5-13 
finding, 5-4 
in custom menus, 30-1 
in Equation Writer, 7-3 
menu of, 5-11 
preventing evaluation, 5-14 
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restrictions, 5-5 
negative 
of arrays, 14-11 
of numbers, 12-13 
newlines, 29-5 
normal distribution, 12-5 
norms (arrays), 14-8 
numbers 
action in programs, 29-2 
appearance, 4-2 
assembling complex from real, 
12-14 
converting complex to real, 
12-14 
converting real to complex, 
12-14 
converting to fractions, 16-5 
disassembling complex into 
real, 12-14 
exponential form, 2-2 
in EquationWriter, 7-3 
internal representation, 4-2 
keying in, 2-1 
random, 12-4 
rounding, 12-9 
truncating, 12-9 
with units, 10-2 


(0) 


= (octal base marker), 15-1 
objects, 2-1, A-2 
actions in programs, 29-2 
converting to graphics objects, 
9-9 
created from command line, 
2-8 
deleting from stack, 3-5 
delimiters for, 2-6 
determing valid types for 
input forms, 6-6 
editing, 2-10 


entering, 2-5 
entering in programs, 29-5, 
29-6 

HP 48-HP 48 I/O, 27-1 

HP 48-PC I/O, 27-9 

in custom menus, 30-1 

printing, 27-2 

storing in variables, 5-6, 5-11 

type numbers of, H-30 

using in input forms, 6-3 

viewing, 2-10 
operations 

categories of, 11-1 
out-of-memory condition, 5-20 
output grid 

GRIDMAP plots, 23-34 
output “slices” 

YSLICE plots, 23-23 
output surfaces 

PR-SURFACE plots, 23-24 

WIREFRAME plots, 23-24 
over-determined systems, 14-14, 

14-17 
estimating solution, 14-15 


p 


packets (Kermit), 27-13 
pages (menus) 
displaying, 1-9 
parabolas 
plotting, 23-11 
PARAMETRIC plots, 23-7 
default step size, 23-8 
display ranges, 23-8 
EQ in, 23-7, 23-9 
plotting ranges, 23-8, 24-3 
TRACE mode, 23-8 
parentheses 
implicit, 7-6 
in algebraics, 11-3 
in complex numbers, 12-12 
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in Equation Writer, 7-5, 7-6 
PARTS menu, 12-9 
past-due alarms, 26-4 
paths, 5-4 
payment modes (TVM), 18-14, 
18-19 
payments (TVM) 
amount of, 18-20 
number of, 18-19 
percent functions, 12-9 
period 
fraction mark, 4-6 
permutations, 12-4 
PICT, 9-6 
copying to stack, 9-5 
resetting, 22-14 
storing picture in, 25-5 
PICTURE environment 
derivatives in, 22-10 
function analysis, 22-9 
integrals in, 22-10 
keyboard in, 22-5 
solving the current equation, 
22-10 
zooming, 22-6 
PICTURE FCN menu, 22-10 
pixels, 9-9 
converting to user-units, 9-9 
coordinates, 9-7 
turning on and off, 9-8 
placeholder variables 
in SOLVE application, 18-3 
PLOT application, 1-6 
differential equation option, 
19-7 
PLOT input forms, 6-7 
plot parameters 
resetting, 22-14 
setting, 22-13 
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plots 


S'DAT and, 22-1, 22-12 

PAR and, 22-16 

adding graphical elements, 
9-3 

analyzing, 22-9 

converting coordinates, 9-9 

coordinate types, 9-7 

equations, 22-1 

expressions, 22-1 

function analysis, 22-9 

functions of two variables, 
23-22 

labeling coordinate axes, 24-1 

output of two-variable plots, 
23-22 

pixel coordinates, 9-7 

pixel operations, 9-8 

plot types, 24-3 

PPAR and, 22-13, 22-14 

programs, 22-1, 24-2 

ranges, 24-3 

reconstructing, 24-7 

resetting plot parameters, 
22-14 

restoring, 24-6 

sampling grid, 23-22 

saving, 24-6 

saving in variables, 24-7 

saving “reconstructable” plots, 
24-7 

setting plot parameters, 22-13 

solving the current equation, 
22-10 

user-defined functions, 24-2 

user-unit coordinates, 9-7 

viewing plots stored in 
variables, 24-7 

VPAR and, 22-15 

zooming, 22-6 
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plot step size 
CONIC plots, 23-13 
FUNCTION plots, 23-3 
PARAMETRIC plots, 23-8 
POLAR plots, 23-5 
TRUTH plots, 23-15 
plotted functions 
analyzing, 22-9 
plotting ranges 
display ranges and, 24-3 
PARAMETRIC plots, 23-8 
POLAR plots, 23-5, 23-6 
TRUTH plots, 23-15 
plotting solutions 
differential equations, 19-7 
stiff differential equations, 
19-9 
plot types 
BAR, 23-19 
CONIC, 23-11, 24-3 
DIFF EQ, 19-7, 23-11 
FUNCTION, 23-1 
GRIDMAP, 23-22, 23-34 
HISTOGRAM, 23-18 
PARAMETRIC, 23-7, 24-3 
POLAR, 23-4, 24-3 
PR-SURFACE, 23-24, 23-35 
PS-CONTOUR, 23-22, 23-30 
SCATTER, 23-20 
SLOPEFIELD, 23-22, 23-25 
TRUTH, 23-14, 24-3 
WIREFRAME, 23-24, 23-28 
YSLICE, 23-23, 23-32 
plug-in cards 
application, 5-1 
environmental limits, A-4 
expanding RAM, 5-1 
expanding ROM, 5-1 
installing, 28-9, 28-12 
new RAM cards, 28-10 
nonapproved, 28-9 


removing, 28-14 
plug-in ports 
installing cards, 28-9 
list of backup objects, 28-4 
removing cards, 28-14 
searching, 28-4 
testing, A-12 
type of memory in, 28-5, 
28-15 
wildcards, 28-4 
pointer (Interactive Stack), 3-6 
Polar coordinate mode, 4-4, 
12-11, 13-1 
POLAR plots, 23-4 
default step size, 23-5 
display ranges, 23-5 
EQ in, 23-4 
plotting ranges, 23-5, 23-6, 
24-3 
TRACE mode, 23-6 
polynomials 
as approximations, 20-12, 
20-15 
converting to algebraic form, 
18-11 
evaluating, 18-11 
finding from roots, 18-10 
finding roots, 18-10 
in Equation Writer, 7-6 
Maclaurin series, 20-12 
Taylor’s, 20-12 
using root-finder, 18-10 
population statistics, 21-6 
port 0 
backing up memory into, 
28-5 


built-in independent memory, 


28-2, 28-3 
libraries in, 28-8 
moving objects into, 28-16 
restoring memory from, 28-6 


port memory 
moving objects into, 28-17 
PPAR 
plot parameters, 22-13 
reserved variable, 5-6 
resetting, 22-14 
precedence 
symbolic operators, 11-3 
top-level function and, 7-10 
unit operators, 10-2, 10-9 
precision, 4-2 
present value (TVM), 18-20 
previous menu 
displaying, 1-10 
FEC annunclator, 1-3, 29-5 
PRG STK menu, 3-11 
principal solutions 
equations and algebraics, 
20-16 
general solutions and, 20-16 
specifying, 20-16 
printers 
infrared, 27-2, 27-3 
printing objects, 27-2 
printing 
objects, 27-2 
to serial port, 27-3 
probability commands, 12-4, 
12-5 
problems, A-1 
PROB menu, 12-4, 12-5 
procedures 
applying to lists, 17-5 
defining, 29-16, 29-18 
Program Development Link, 
27-7 
Program-entry mode, 2-9, 29-5 
programs, 22-1, 29-1 


actions for object types, 29-2 


applying to lists, 17-4 
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Index 


Index 


are sequences of objects, 29-1, 
29-2 

“building-block” , 29-5 

calculation styles, 29-4 

compared to libraries, 28-6 

conditional structures, 29-10, 
29-15 

debugging, 29-8 

editing, 29-8 

elapsed time, 16-4 

entering, 29-5 

entering algebraics in, 2-9 

entry modes, 2-9, 29-5 

evaluating local variables, 
29-17 

evaluating variables 
containing, 5-13 

executing, 29-6 

flow of, 29-4 

HALT annunciator, 29-9 

halting, 29-9 

in local variable structure, 
29-3, 29-16 

killing, 29-9 

local variable structures, 29-3, 
29-16 

loop structures, 29-12 

naming, 29-6 

newlines in, 29-5 

not evaluating local variables, 
29-17 

objects in, 29-2 

on the stack, 29-5 

plotting, 22-1, 24-2 

resuming, 29-9 

scope of local variables in, 
29-18 

single-step execution, 29-8, 
29-9 

solving, 18-2 

stopping, 1-8, 29-7 
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storing, 29-6 

structured, 29-4 

structures in, 29-3 

subroutines, 29-5 

trapping errors, 29-15 

user-defined functions, 29-19 

viewing, 29-8 
PR-SURFACE plots, 23-35 

EQ in, 23-36 

eyepoint, 23-37 

output surfaces, 23-24 

view volume, 23-37 
PRTPAR 

reserved variable, 5-6 
PS-CONTOUR plots, 23-30 

output grid, 23-22 
purging 

backup objects, 28-4 

Equation Library variables, 

25-5, A-3 
memory, 5-17 
variables, 5-10, 25-5, A-3 


Q 


quadratic equations 
solving, 20-15 


* annunciator, 12-11, 13-2 
Raa annunciator, 12-11, 13-2 
FAL annunciator, 1-3, 4-3 
radians 

converting to degrees, 12-7 
Radians angle mode, 4-3 
Radians mode, 4-10 
RAM cards 

as independent memory, 

28-15 

as merged memory, 28-15 

backing up memory, 28-5 

battery (initial), 28-10 


battery preserves memory, 
28-15 
battery type, A-5 
expanding user memory, 5-1, 
28-16 
for backup objects, 28-3 
free before removing, 28-14 
freeing, 28-16, 28-17 
initializing, 28-14 
installing, 28-9, 28-12 
memory types, 28-15 
moving objects into, 28-17 
new, 28-10 
removing, 28-14 
replacing battery, A-7 
restoring memory, 28-6 
testing, A-12 
type of memory in, 28-5, 
28-15 
write-protect switch, 28-12, 
28-17 
random numbers, 12-4 
REAL menu, 12-7, 12-9 
real numbers 
complex results, 12-13 
converting to binary integers, 
15-3 
converting to complex, 12-14 
converting to complex 
numbers, 12-14 
converting to fractions, 16-5 
recalling 
backup objects, 28-3 
HP 48 memory from computer, 
27-13 
last arguments, 3-5 
last command lines, 2-10 
memory from backup object, 
28-6 
user key assignments, 30-7 
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rectangles 
drawing, 9-8 
Rectangular coordinate mode, 
4-4, 12-11, 13-1 
Rectangular mode, 4-10 
repair service, A-16 
repeating alarms, 26-5 
replace cursor, 2-12 
reserved variables, 5-6 
resetting 
flags, 4-9 
input form fields, 6-6 
memory, 5-17 
PICT, 22-14 
plot parameters, 22-14 
PPAR, 22-14 
restoring 
last stack, 3-6 
root-finder 
displaying, 18-5 
halting and restarting, 18-5 
used by Multiple-Equation 
Solver, 25-8, 25-10 
roots, 18-2 
in Equation Writer, 7-4 
in PICTURE environment, 
22-10 
multiple, 25-11 
rotate (binary integers), 15-5 
rounding numbers, 12-9 
row vectors, 8-1, 8-8 
RULES menu, 20-21 
Rules transformations, 20-27 


S 


sÍ 
general solutions (+ or —), 
20-16 
reserved variable, 5-6 
sample statistics, 21-6 
sampling grids, 23-22 
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SCATTER plots, 23-17 
comparing to regression, 
23-21 
from Statistics, 23-20 
Scientific display mode, 4-2 
scrolling in Equation Writer, 
7-2, 7-10, 7-13 
Selection environment 
editing subexpressions, 7-11, 
7-12 
EquationWriter mode, 7-2, 
7-13 
Rules transformations, 20-19 
self-test, A-10 
semicolon 
complex number separator, 
12-12 
sequences, 17-1 
finding first differences, 17-8 
finding product of elements, 
17-8 
generating, 17-7 
serial cable, 27-7 
serial port 
connecting printer, 27-3 
for printing, 27-3 
testing, A-14 
wiring, 27-7 
serial printers, 27-2, 27-3 
service repair, A-16 
setting flags, 4-8 
shift (binary integers), 15-5 
shift keys 
annunciators, 1-6 
canceling, 1-6 
in custom menus, 30-4 
keyboard and, 1-4 
operation, 1-4 
significant digits 
displayed, 4-2 
rounding to, 12-9 
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sign reversal 
in SOLVE application, 18-4 
single-step execution of 
programs, 29-8, 29-9 
single-variable statistics, 21-6 
SI units 
base units, 10-2 
converting to, 10-6 
size 
of built-in ROM, 5-1 
of memory, 5-1, A-1 
of stack, 3-11 
of variables, 5-11 
slope 
calculating, 22-10 
SLOPEFIELD plots, 23-25 
EQ in, 23-26 
output grid, 23-22 
Snedecor’s F distribution, 12-5 
SOLVE application, 1-6, 18-1 
bad guesses, 18-5 
compared to Multiple- 
Equation Solver, 25-3 
constant-valued equations, 
18-5 
displaying root-finder, 18-5 
getting solutions with units, 


18-6 
halting and restarting root- 
finder, 18-5 


interpreting intermediate 
guesses, 18-5 
interpreting results, 18-3, 
18-4 
menu actions, 25-3 
messages, 18-3 
rearranging variables, 18-6 
sign reversal, 18-4 
SOLVR environment, 18-6 
used by Equation Library, 
25-2 


using units with, 18-6 
SOLVE differential equation 
solver 
accuracy of results, 19-5 
STIFF solver, 19-4 
SOLVE input forms, 6-7 
SOLVEQN command, F-1 
solver menu (Equation Library) 
actions, 25-3, 25-7 
solvers (Equation Library) 
choosing, 25-2 
compared, 25-3 
starting, 25-2 
SOLVR environment 
compared with SOLVE 
application, 18-6 
creating custom menus, 18-9 
Multiple Equation Solver and, 
18-8 
options not in SOLVE, 18-8 
solving series of equations, 
18-8 
using, 18-6, 18-7 
special characters 
keying in, 2-4 
viewing, 2-4 
Spherical coordinate mode, 4-5, 
12-11, 13-1 
Spherical mode, 4-10 
stack 
calculations on, 3-1, 29-4 
chain calculations, 3-3 
command line and, 1-4 
deleting objects, 3-5, 3-7, 
3-11 
diagrams, 29-4 
displaying, 1-8 
duplicating entries, 3-4 
dynamic size, 1-3 
input forms and, 6-5 
Interactive Stack, 3-7 
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last, 3-6 
manipulating, 3-7, 3-11 
moving objects, 3-7, 3-11 
operation, 1-3, 3-1 
pointer, 3-6 
putting objects into algebraics, 
7-11, 7-12, 20-20 
recalling last arguments, 3-5 
restoring last, 3-6 
rolling objects, 3-7 
saving as graphics object, 
9-10 
size of, 3-11 
swapping levels, 3-4 
viewing, 3-7 
STACK application, 1-6 
stack display 
organization, 1-1 
returning to, 1-8 
viewing graphics objects, 
9-10 
stack displays 
converting to graphics objects, 
9-10 
stack syntax, 3-1 
in local variable structures, 
29-4 
user-defined functions, 11-8 
Standard display mode, 4-2 
“start” looping, 29-12 
STAT application, 1-6 
statistical data 
editing, 21-4 
entering, 21-1, 21-2 
in X DAT, 21-1 
plotting, 21-7, 21-11, 23-17 
plot types, 23-17 
population data, 21-6 
probabilities, 12-5 
sample data, 21-6 
test statistics, 12-4 
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upper-tail probabilities, 12-5 
Statistics 
DAT data, 21-1 
X PAR parameters, 21-12 
BAR plots, 23-19 
current matrix, 21-1, 21-2 
data structure, 21-1 
editing data, 21-4 
entering data, 21-1, 21-2 
HISTOGRAM plots, 23-18 
plotting data, 23-17 
plot types, 23-17 
population, 21-6 
probabilities, 12-5 
sample, 21-6 
SCATTER plots, 23-20 
single-variable, 21-6 
statistical data, 21-1 
test statistics, 12-4 
upper-tail probabilities, 12-5 
status area, 1-1, 5-3 
stiff initial value differential 
equations 
solving, 19-4 
STK menu, 3-11 
storing 
memory in backup object, 
28-5 
memory on computer, 27-12 
objects in variables, 5-6, 5-11 
programs, 29-6 
user key assignments, 30-6 
strings 
action in programs, 29-2 
creating from algebraics, 7-14 
in custom menus, 30-1 
sending to serial port, 27-18 
structured programming, 29-4 
Student’s t distribution, 12-5 
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subdirectories 
in custom menus, 30-1, 30-3 
subexpressions, 7-10, 20-18, 
20-19 
editing, 7-10, 20-20 
putting on stack, 20-20 
rearranging, 20-19 
replacing, 7-12, 20-20 
submenus 
indicated by label bar, 5-4 
selecting, 1-9 
subroutines 
debugging, 29-9 
in programs, 29-5 
single-step execution, 29-9 
summations 
in Equation Writer, 7-5 
swapping stack levels, 3-4 
SYMBOLIC application, 1-7 
symbolic constants 
evaluating, 11-5 
flags affect, 11-5 
symbolic integration patterns, 
20-30 
symbols (alpha keyboard), 2-3 
syntax 
algebraic, 11-2 
stack, 11-3 
system flags 
checking for math errors, 
18-5 
system halt, 5-16 
systems of equations 
“best” solution, 14-15 
Gaussian elimination, 14-18 
over-determined, 14-14, 14-15, 
14-17 
solution accuracy, 14-17 
solving, 14-12, 14-14, 14-15, 
14-18 


under-determined, 14-14, 
14-15, 14-17 


T 
Taylor’s polynomials 
and derivatives, 20-13 
calculating, 20-12 
t distribution, 12-5 
temperatures 
calculations, 10-11 
calculator limits, A-4 
converting, 10-10 
differences, 10-10, 10-11 
levels, 10-10, 10-11 
plug-in card limits, A-4 
units of measure, 10-10 
test commands 
in conditional structures, 
29-10 
in loop structures, 29-14 
testing 
calculator, A-9 
flag states, 4-8 
pixels, 9-9 
test statistics, 12-4 
three-dimensional plots 
constraints, 23-25 
coordinates relative to display, 
23-25 
GRIDMAP, 23-34 
PR-SURFACE, 23-35 
PS-CONTOUR, 23-30 
SLOPEFIELD, 23-25 
WIREFRAME, 23-28 
YSLICE, 23-32 
ticks (system clock), 16-4 
time 
arithmetic with, 16-4 
as ticks, 16-4 
calculations, 16-3 
converting formats, 16-3 


converting to number, 16-1, 
16-3 

displaying, 4-10 

elapsed time, 16-4 

format options, 16-1, 26-1 

HMS format, 16-3 

setting the current, 16-3 
TIME application, 1-7 
timeout (serial), 27-18 
too few arguments, A-3 
top-level function, 7-10, 20-18 
TRACE mode 

cursor coordinates and, 22-4 

FUNCTION plots, 23-3 

PARAMETRIC plots, 23-8 

POLAR plots, 23-6 
transforming columns, 21-5 
transforming rows, 21-5 
transmit modes 

HP 48-to-HP 48, 27-1 
trigonometric functions, 10-8, 

12-2, A-2 

truncating numbers, 12-9 
TRUTH plots, 23-14 

default step size, 23-15 

display ranges, 23-15 

EQ in, 23-14 

plotting ranges, 23-15, 24-3 
TVM calculations, 18-13 

payment modes, 18-14 

performing, 18-16 
TVM menu, 18-20 
two’s complement, 15-2, 15-3 
typing aids, 30-1 


U 
under-determined systems, 
14-14, 14-17 
estimating solutions, 14-15 
unit objects 
calculations with, 10-7 
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calculations with 
temperatures, 10-11 

consistent units, 10-8 

converting angular units, 
10-7 

converting units, 10-6 

converting units of 
temperature, 10-10 

creating, 10-3, 10-4, 11-1 


creating graphics objects from, 


9-9 
creating in Equation Writer, 
7-6 
delimiters, 10-2 
factoring units, 10-9 
in algebraics, 10-9 
in custom menus, 30-1 
inverse units, 7-6, 10-3 
numeric part, 11-1 
precedence of delimiter, 10-9 
precedence of unit operators, 
10-2 
prefixes for units, 10-4 


units 


affect results, 25-10 

consistent, 10-8, 25-10 

converting, 10-6 

dimensionless, 10-7 

Equation Library, 25-15 

implied, 25-11 

initializing in Equation 
Library, 25-2 

SI vs. English, 25-2, 25-5, 
25-11, A-3 

solving for unknown variables 
with, 18-6 

unexpected, 25-11 

user-defined, 10-14, 25-15 

wrong, A-3 

UNITS application, 10-1 
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units catalog 
Equation Library, 25-5 
UNITS Catalog menu, 10-1, 
10-2, 10-6 
UNITS Command menu, 10-1 
units of measure 
based on SI units, 10-2 
case-sensitive names, 10-3 
converting, 10-6 
converting angles, 10-7 
converting temperatures, 
10-10 
deleting, 11-1 
dimensionally consistent, 10-8 
entering in Equation Writer, 
7-6 
factoring, 10-9 
in calculations, 10-7, 10-11 
in custom menus, 30-1 
inverse, 7-6, 10-3 
operators, 10-2 
prefixes, 10-4 
temperature differences, 10-11 
temperature units, 10-10, 
10-11 
units options (Equation Library), 
25-1 
affect equation solution, 25-10 
effect of no units, 25-11 
uppercase letters 
in units, 10-3 
keying in, 2-4 
upper-tail probabilities, 12-5 
LESER annunciator, 1-3, 30-5 
user-defined derivatives, 20-11 
user-defined functions, 11-6 
arguments, 11-7, 11-8 
creating, 11-7 
differentiating, 20-11 
executing, 11-7 


t 


internal structure, 29-18, 
29-19 
nesting, 11-8 
plotting, 24-2 
user-defined transformations, 
20-27 
user-defined units, 10-14, 25-15 
user flags, 1-3, 4-9 
user keys 
activating, 30-5 
assigning, 30-5 
disabling, 30-7 
editing assignments, 30-8 
operation, 30-4 
packing assignments, 30-8 
recalling assignments, 30-7 
unassigning, 30-6 
user memory, 5-1 
expanding, 28-15, 28-16 
user modes 
activating, 30-5 
annunciators for, 1-3 
assigning keys, 30-5 
disabling keys, 30-7 
getting unstuck, 30-8 
operation, 30-5 
unassigning keys, 30-6 
user-unit coordinates, 9-7 
user-units 
converting to pixels, 9-9 
DAT 
plots and, 22-1, 22-12 
LLESE annunciator, 1-3, 30-5 


V 
variable catalogs 
Equation Library, 25-5 
variables 
action in programs, 29-2 
creating, 5-6, 5-13, 11-4 
directories in, 5-4 


duplicate names, 5-4 

editing, 2-10 

entering names, 5-14 

evaluating, 5-11, 5-13, 5-14 

evaluating selectively, 20-17 

evaluating variables 
containing, 5-13 

finding, 5-4, A-3 

HP 48-HP 48 I/O, 27-1 

HP 48-PC I/O, 27-9 

in custom menus, 30-1 

in EquationWriter, 7-3 

in other directories, 5-4 

isolating in an algebraic, 
20-15 

menu of, 5-11 

naming, 5-5 

placeholder, 18-3 

preventing evaluation, 5-14 

protecting during I/O, 27-11 

purging, 5-12, 25-5, A-3 

quoted names, 5-14 

recalling contents, 5-11 

reserved names, 5-6 

saving plots in, 24-7 

separating into directories, 
5-3 

showing hidden, 20-17 

solving for values, 22-10 

solving symbolically, 20-14, 
20-15 

storing objects in, 5-6, 5-11 

unquoted names, 5-14 

viewing, 2-10 

viewing plots stored in, 24-7 


variables (Equation Library) 


equation design, 25-8 

initializing, 25-2 

involved in solution, 25-8, 
25-10, 25-11 

not detected, 25-9 
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states, 25-8 

too many known, 25-11 

too many unknown, 25-10 

unexpected solutions, 25-10 

wrong states, 25-11 
variables (Solver) 

global, 25-2, 25-5, A-3 
VAR menu, 5-4, 5-11 

displays directories, 5-4 
vectors, 8-1 

angle between, 13-5 

assembling, 13-3 

calculations, 13-4 

column, 8-1 

coordinate modes, 4-4, 13-1 

delimiters, 13-3 

disassembling, 13-4 

displayed, 4-4 

displaying, 13-1 

entering, 2-7, 8-4, 8-8, 13-3 

internal representation, 4-4, 

13-3 

normalized, 13-3 

row, 8-1 

unit vector, 13-5 
VECTR menu, 13-2, 13-4 
view volume, 23-24 

PR-SURFACE plots, 23-37 

WIREFRAME plots, 23-28, 

23-30 

YSLICE plots, 23-33 
VPAR 

and plots, 22-15 


W 


warranty, A-15 
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where function 

in Equation Writer, 7-6 
“while” looping, 29-14 
wildcards 

backup objects, 28-4 

in user-defined 

transformations, 20-27 

WIREFRAME plots, 23-28 

eyepoint, 23-30 

output surfaces, 23-24 

view volume, 23-28, 23-30 
wordsize (binary) 

bits lost, 15-2 

recalling, 15-2 

setting, 15-2 
write-protect switch, 28-12, 


28-17 

x 

XON/XOFF handshaking, 27-3, 
27-17 

Y 


YSLICE plots, 23-32 
animating, 23-33 
output, 23-23 
view volume, 23-33 


Z 


zero value 
in SOLVE application, 18-4 
zoom defaults 
ZPAR and, 22-13 
zooming, 22-6 
selecting a zoom, 22-7 
setting defaults, 22-7 
ZPAR 
zoom parameters, 22-13 


Contacting Hewlett-Packard 


For Information about Using the Calculator. If you have 
questions about how to use the calculator, first check the table of 
contents, the subject index, and “Answers to Common 
Questions” in appendix A of the this manual. If you can’t find 
an answer, you can contact the Calculator Support Department: 


Hewlett-Packard 

Calculator Support 

1000 N.E. Circle Blvd. 

Corvallis, OR. 97330, U.S.A. 

(503) 715-2004 (Mon.—Fri., 8:00am~3:00pm Pacific time) 
(503) 715-3628 FAX 


For Hardware Service. See appendix A of this manual for 
diagnostic instructions and information on obtaining service. 
But, before you send your unit for service, please call HP 
Calculator Support at the number listed below. 


Hewlett-Packard 

Corvallis Service Center 

1030 N.E. Circle Blvd., Bldg. 11 
Corvallis, OR 97330, U.S.A. 

(503) 715-2004 (HP Calculator Support) 


If you are outside the United States, see appendix A for 
information on locating the nearest service center. 


HP Electronic Information Service. This service provides 
information on HP 48 calculators and is free of charge—you pay 
only for the phone call or Internet service. There are two ways to 
connect: 


mw via modem: (503)715-4448. It operates at 2400/9600/14400 
baud, full duplex, no parity, 8 bits, 1 stop bit. 

m via the Internet: Access as hpcvbbs.external.hp.com 
(192.6.221.13) using telnet, ftp, or World-Wide-Web browser 
(http://hpevbbs.external.hp.com/hp48g.html). 
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21: Statistics and Data Analysis 
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